Minulla on mysql-kannassa taulu, joka sisältää sukulaisuuksia (siis lapsi tietää äitinsä ja isänsä, äiti tietää äitinsä ja isänsä jne). Näistä haluaisin hakea funktiolla rekursiivisesti jonkun tietyn henkilön sukulaisia. Ongelma on siinä, että koska haen sekä isovanhempi, että myös näiden lapsia, niin en voi tietää montako nimeä funktio palauttaa. Useimmiten arvo on noin 20 luokkaa, mutta pahimmassa tapausessa sieltä voi tulla jopa tuhansia nimiä.
Kanta oli alunperin postrgresql ja siellä homma hoitui siten, että funktio keräsi varchar-taulukkon ekaan soluun nimiä pilkulla erotettuna ja palautti sitten tuon taulukon (jossa oli siis vain yksi alkio, joka oli hillittömän pitkä string).
Miten homma kannattaisi hoitaa mysql:n puolella? Manuaalin mukaan siellä ei tunneta varchar-taulukoita ja tavalliseen varchar-kenttään pitäisi aina liittää pituus, josta siis ei ole etukäteen tietoa.
ysql funktiosta paluuparametrina vaihtelevan mittainen string
jaana77
1
414
Vastaukset
http://forums.mysql.com/read.php?118,208679,208718#msg-208718
> Manuaalin mukaan siellä ei tunneta varchar-taulukoita ja tavalliseen varchar-
> kenttään pitäisi aina liittää pituus, josta siis ei ole etukäteen tietoa.
Mitäs jos palauttaisi string -tietotyyppiä olevan ötökän?
Minä tietenkään en mitään MySQL:stä tiedä...
Itse käyttäisin ehkä temppitaulua kuitenkin. Tai koodaisin haun logiikan jonnekin muualle (php:llä tai millä ikinä softaa tekeekin).
Ketjusta on poistettu 0 sääntöjenvastaista viestiä.
Luetuimmat keskustelut
- 741094
- 691024
- 47952
Miltä se tuntuu
Miltä se tuntuu havahtua, että on ollut ihmistä kohtaan, joka on rakastanut ja varjellut, täysi m*lkku? Vai havahtuuko s104948- 51895
- 49694
- 32674
Mitä se olisi
Jos sinä mies saisit sanoa kaivatullesi mitä vain juuri nyt. Ilman mitään seuraamuksia yms. Niin mitä sanoisit?34587- 50580
- 38536