Pereiti prie turinio

kaip talpinti masyvą i duombazę?


Rekomenduojami pranešimai

Sveiki,

iškilo klausimas kaip pataplinti masyvus sql duombazėje. Tarkim noriu forumui sukurti balsavimo sistemą, kurioje galėtų dalyvauti tik registruoti vartotojai. Panašu kad čia be masyvų nekaip, nes manau reikės dviejų masyvų:

* balsavimo variantai

* kiek balsų gavo kiekvienas variantas

* vartotojai kurie balsavo

 

Tai dabar galvoju, kaip geriau viską sutvarkyti - viską dėti į viena lentelę, tarkim:

* table polls
poll_id | array_variantai | array_rezultatai | array_kas_balsavo
----------------------------------------------------------------
1         a b c             1  3  2            a tu jis ji   

 

ar viską išskirstyti į kelias lenteles

 

*table poll_main_info
poll_id | table_variantai | table rezutatai | table_kas_balsavo
----------------------------------------------------------------
1         t_poll_1         t_rez_1            t_voters_1


* t_poll_1
variantai |
-----------
a
b
c

* t_rez_1
rezultatai |
------------
1
2
3

* t_voters_1
balsavo |
---------
as
tu
jis
ji

 

ar kažkaip kitaip viską galima daryti?

Tai va, tikiuosi, kad supratot mane ir ko aš noriu ir kad nenusigrybavau į pievas :D

Nuoroda į pranešimą
Dalintis kituose puslapiuose

Ne, ne, ne. Visai ne taip daroma su reliacinėmis duomenų bazėmis :)

apklausos
---------
id   
---------
1

~~~~~~~~~~~~

apklausu_variantai
------------
id  | tekstas | apklausos_id
  1     Taip              1
  2       Ne              1

~~~~~~~~~~~~

balsai
-------------
id  | apklausos_id | varianto_id | vartotojo_id
1                1             1              6
2                1             1              5
3                1             2             13

 

Žinoma, daugiau lentelių, reikės joinų, bet daug lanksčiau. Apskritai, SQL masyvas į vieną laukelį nekišamas (išskyrus, tarkime, Postgres ARRAY tipą – bet net ir ten naudojama ne tokiems atvejams, kaip tavo).

 

Pagalvok, kaip su savo struktūra, pavyzdžiui, atsirinktum, kurie vartotojai už ką balsavo?

 

Tavo antras variantas – kurti po tris lenteles kiekvienai apklausai – išvis beprotiškas

Redagavo Silke
Nuoroda į pranešimą
Dalintis kituose puslapiuose

Prisijunkite prie diskusijos

Jūs galite rašyti dabar, o registruotis vėliau. Jeigu turite paskyrą, prisijunkite dabar, kad rašytumėte iš savo paskyros.

Svečias
Parašykite atsakymą...

×   Įdėta kaip raiškusis tekstas.   Atkurti formatavimą

  Only 75 emoji are allowed.

×   Nuorodos turinys įdėtas automatiškai.   Rodyti kaip įprastą nuorodą

×   Jūsų anksčiau įrašytas turinys buvo atkurtas.   Išvalyti redaktorių

×   You cannot paste images directly. Upload or insert images from URL.

Įkraunama...
  • Dabar naršo   0 narių

    Nei vienas registruotas narys šiuo metu nežiūri šio puslapio.

  • Prisijunk prie bendruomenės dabar!

    Uždarbis.lt nariai domisi verslo, IT ir asmeninio tobulėjimo temomis, kartu sprendžia problemas, dalinasi žiniomis ir idėjomis, sutinka būsimus verslo partnerius ir dalyvauja gyvuose susitikimuose.

    Užsiregistruok dabar ir galėsi:

    ✔️ Dalyvauti diskusijose;

    ✔️ Kurti naujas temas;

    ✔️ Rašyti atsakymus;

    ✔️ Vertinti kitų žmonių pranešimus;

    ✔️ Susisiekti su bet kuriuo nariu asmeniškai;

    ✔️ Naudotis tamsia dizaino versija;

    ir dar daugiau.

    Registracija trunka ~30 sek. ir yra visiškai nemokama.

  • Naujausios temos

  • Karštos temos

×
×
  • Pasirinkite naujai kuriamo turinio tipą...