Sasa Posted January 23, 2008 Report Posted January 23, 2008 Ir tabula ar produktiem, bet zem produktiem ir pakārtota vesele virkne dežādu lietu. Un tagad radās vajadzība piesaistīt produkta kodam vēl vienu vērtību. Kā labāk būtu kaut kā tajpašā tabulā ar visām pārējam vērtībam glabāt šo jauno vērtību, vai arī izveidot jaunu tabulu, kurā arī glabāsies man šī vērtība?
andrisp Posted January 23, 2008 Report Posted January 23, 2008 (edited) Neredzu jēgu glabāšanai atsevišķa tabulā, tikai liekas klapatas. Edited January 23, 2008 by andrisp
Aleksejs Posted January 23, 2008 Report Posted January 23, 2008 Ja katram produktam ir tieši viena jaunā vērtība un nav svarīgi, kādas vērtības bija iepriekš - tad pareizāk pievienot jaunu kolonnu tabulai. Ja vērtības var būt vairākas un nav zināms, cik, tad veidot atsevišķu tabulu.
Delfins Posted January 23, 2008 Report Posted January 23, 2008 Ja tas ir raksturošs parametrs, tad citā tabulā. Piekrītu Aleksejam.
andrisp Posted January 23, 2008 Report Posted January 23, 2008 Delfins, ko nozīmē "raksturošs parametrs" ?
Sasa Posted January 23, 2008 Author Report Posted January 23, 2008 taisīšu tā, ka jau ir aizpildīta tabula ar visām vērtībām. Izvēlos pievienot jaunu vērtību produktam pēc koda, tad tajā tabulā kurā ir visas vērtības izveidoju janu kolonu kurā savadīšu jaunpievienotās vērtības!
Delfins Posted January 23, 2008 Report Posted January 23, 2008 Delfins, ko nozīmē "raksturošs parametrs" ? Jebkas, kas raksturo produktu - krāsa, izmērs un t.t. Bet tādi parametri, kā cena, mērvienības, pvn grupas un t.t. nav raksturoši. - tīri finansiālā informācija. Dzīvoklim nekad nebūs gigabaiti, un DVD diskam nekad nebūs virtuves platība ;) //pliks piemērs
andrisp Posted January 23, 2008 Report Posted January 23, 2008 Delfins, nu skaidrs kā tu to domāji, bet tad gan drīzāk tas ir nevis "raksturojošs elements", bet gan elements, kas var neattiekties uz visiem produktiem. Cena un cita finansiālā informācija jau arī ir raksturojošs elements. Tāpat arī, piemēram, ja man ir zeltlietu veikals, tad būtu tikai normāli, ja galvenajā tabulā būtu papilduslauks "prove". Enīvei, tas viss ir atkarīgs no situācijas.
Sasa Posted January 23, 2008 Author Report Posted January 23, 2008 :( nevaru izdomāt kā būtu prātīgāk un sakarīgāk.! Ir tabula kurā sevī ietver produkta kodu un tā specifikāciju, ja ir nepieciešamība pēc jauna produkta tad sākumā pievieno db jauna produkta kodu un tad pāriet pie iespējas šim prouktam pievienot specifikāciju! Bet tagad radās vajadzība, ka vajag pie katra produkta koda piesaistīt vēl vienu lauku, kurš saturētu skaitlisku vērtību. Biegās kad db ir savākusi pietiekami daudz info. var sākt strādāt ar datiem. Ar iespēju sastādīd sarakstu ar nepieciešamo produktu kodiem, kad saraksts ir sastādīts, tad visa to produktu specene parādās garā sarakstā, bet pie atskaitēm notiek datu atlase un apstrāde un vienā no atskaitēm ir jāparās tā jaunā pievienotā lauka skaitlikso vērtību summai, jo katram izvēlētajam produktam tajā laukā var būt savādāka vērtība!
Delfins Posted January 23, 2008 Report Posted January 23, 2008 (edited) Ar to arī labāka sub-tabula, kas ļaus veikt neatkarīgu grupēšanu. andrisp, atkal aizšāvi garām - prove kāreiz ir raksturošs parametrs... Arī cenu īstenībā var neglabāt kā kopējo parametru, jo ir tādas lietas, kā cenu atlaides pēc klientiem, daudzuma, datuma un citiem parametriem. Man ir tā uztaisīts, izņemot cenas (nepabeigts i-veikals): PRECE [preces_id] CENAS [preces_id, datums_no, datums_lidz, klienta_id, klientu_grupas_id, min_daudzums, max_daudzums] PARAMETRI [preces_id, parametra_id, vertiba_str, vertiba_real, vertiba_date] PRECU_GRUPAS[preces_grupas_id,nosaukums] PRECES_GRUPAS[preces_id,preces_grupas_id] PARAMETRU_GRUPAS[grupas_id,nosuakums] PARAMETRA_GRUPAS[parametra_id,parametra_grupas_id] PRECU_GRUPAS_PARAM_GRUPAS[precu_grupas_id,parametru_grupas_id] Iz-dzīves piemērs -Monitori (Param-grupas: gabariti, displeju_izskirspeja, monitori) -- LCD (Param-grupas: lcd_monitoru_papildus) -- CRT (Param-grupas: crt_monitoru_papildus) Atliek produktam pielikt konkretas grupas, un vinš mantos visus tās parametrus (kā to reāli māca C++ OOP kursos, kad māca inheritance un t.t.) Vēlāk varēs ar papild-kāsīšiem iezīmēt tās grupas/parametrus, pēc kurām varēs smuki filtrēt (ar AJAX palīdzību, metaleks.lv i-veikals piemērs) Edited January 23, 2008 by Delfins
andrisp Posted January 23, 2008 Report Posted January 23, 2008 Es jau neteicu, ka prove nav raksturojošs. Es tikai saku, ka ja elements attieksies uz visiem produktiem un tam var būt tikai viena vērtība (kā piemēram zeltlietu katalogā, kur visiem produktiem ir prove), tad kāpēc gan to neglabāt galvenajā tabulā ?
Delfins Posted January 23, 2008 Report Posted January 23, 2008 andrisp, ja pieņem, ka jau ir sub-tabulu modelis, tad nav jēgas likt papildus lauku. Cik sapratu, topika autoram viss vienā tabulā un bez normāliem lauku nosaukumiem (datums_1,cipars_1, cipars_2)
andrisp Posted January 23, 2008 Report Posted January 23, 2008 (edited) Delfins, tā īsti arī nav. Tādejādi es varētu nodalīt, piemēram, obligātos laukos, kas obligāti ir visiem produktiem definēti (liekot tos produktu tabulā), no opcionālajiem/specifiskajiem elementiem, kas tiek realizēti ar papildus tabulas palīdzību. (Godīgi sakot es nezinu kā īsti autoram viss ir realizēts, jo to #9 mistrojumu nesapratu. No offence, protams.) Edited January 23, 2008 by andrisp
Delfins Posted January 23, 2008 Report Posted January 23, 2008 (edited) kas obligāti ir visiem produktiem definēti Pieliec klāt parametram kašīti "obligāts". Ja vajag vēlāk izvilkt pēc "loģikas", pieliec klāt kolonnu "LOGISKAIS_TIPS"/"ELEMENTS"/whatever... Tādējādi tu iegūsti pilnīgi konfigurējamu produktu bez programmēšanas. Vēlāk to visu kešot un nekādu problēmu ;) TOpika autors, uztaisa tabulu struktūras dumpu Edited January 23, 2008 by Delfins
andrisp Posted January 23, 2008 Report Posted January 23, 2008 Pieliec klāt parametram kašīti "obligāts". Nu, protams, var jau visādi. :)
Recommended Posts