Autor | Zpráva | ||
---|---|---|---|
Mufna Profil |
#1 · Zasláno: 1. 12. 2008, 17:07:05
Zdravím Vás. Je nějaký (praktický) rozdíl mezi tím, když u různých tabulek v databázi používám pro název políčka s ID "id_neco" ? Tedy ne jenom "id" ? Všiml jsem si, že někdo používá vždy je název "id".
|
||
nightfish Profil |
#2 · Zasláno: 1. 12. 2008, 17:11:46
osobně používám všude "id", protože "id_neco" neposkytuje žádnou informaci navíc
navíc by mohlo dojít k záměně a mohl bych "id_neco" považovat za cizí klíč odkazující na `neco`.`id` (ač pro označení cizích klíčů používám příponu _id) |
||
Tomasds Profil |
#3 · Zasláno: 1. 12. 2008, 17:18:06
Zrovna včera jsem se tady chtěl přeptat na řešení dvou ID při joinování.
Vždycky jsem používal ID, ale poslední dobou začínám používat IDzbozi, IDvystavy, IDfilmu apod, protože když chci komplet výpis ze dvou JOINovaných tabulek, tak můžu použít SELECT * FROM a nemusím se vypisovat s jednotlivými poli jen kvůli SELECT filmy.ID as IDfilmu apod. snad to píšu srozumitelně. |
||
Pajah Profil |
#4 · Zasláno: 1. 12. 2008, 18:53:37
Já například taky používám s id nějakou předponu.
Třeba když mám tabulku forum_fora, tak ffid, forum_temata, tak ftid, jak tu bylo zmíněno, u JOINů je to mnohem lepší. |
||
igamenir Profil |
#5 · Zasláno: 1. 12. 2008, 18:57:46
taky používám jen id
samotné id považuju za identifikaci daného záznamu, a třeba userid, itemid, ownerid .. za identifikaci jiného záznamu |
||
Tomasds Profil |
#6 · Zasláno: 1. 12. 2008, 19:36:46
ok, tak si dovolím zneužít toto vlákno ke svému poddotazu.
Mám dvě tabulky, danou vazbu, potřebuju z nich vytáhnout něco. SELECT filmy.ID as fID, filmy. nazev, reziseri.ID as rID, reziseri.jmeno FROM filmy LEFT JOIN reziseri ON filmy.IDrezisera = reziseri.ID Tady mě zajímají 4 sloupce. Ale často potřebuju všechny nebo skoro všechny, takže by se hodilo místo vypisování 20 sloupců toto: SELECT * FROM filmy LEFT JOIN reziseri ON filmy.IDrezisera = reziseri.ID To můžu udělat za předpokladu, že v tabulkách nemám ID, ale IDfilmu, IDrezisera. Dá se toto nějak udělat, když budu mít v tabulkách sloupec ID? Jde mi o to, abych nemusel vypisovat všechny sloupce kvůli jednomu nebo dvěma "as". Byl bych samozřejmě radši, protože chápu igamenira, cítím to stejně. |
||
Kajman_ Profil * |
#7 · Zasláno: 1. 12. 2008, 20:25:05
Můžete vypsat vše a navíc pojmenové id.
SELECT f.*,r.*,r.id rid, f.id fid FROM filmy f LEFT JOIN reziseri r ON f.IDrezisera = r.ID |
||
Časová prodleva: 3 dny
|
|||
joe Profil |
#8 · Zasláno: 4. 12. 2008, 21:46:53
Stačí jen "id". Není třeba nic připisovat, protože pokud vybíráš jen z jedné tabulky, víš že to bude id. Pokud vybíráš z více tabulek, zápis bude tabulka.id, takže zase víš, odkud to id je. Nechápu proč ve škole u nás na škole používají zbytečně zdlouhavý název a to id_neco (označují tak primární klíče), když je to zbytečné. Pokud v tabulce mám id a pak další id, které vedou na jiné id v jiných tabulkách, pak použiju zápis id_kamtovede, abych to poznal.
|
||
Tomasds Profil |
#9 · Zasláno: 4. 12. 2008, 22:34:42
joe nepochopil, Kajman_ pochopil, díky.
|
||
joe Profil |
#10 · Zasláno: 4. 12. 2008, 23:08:15
Tomasds
Promiň, já neodpovídal přímo tobě :) Mě si nevšímejte, Kajman_ je odborník na MySQL :) |
||
Tomasds Profil |
#11 · Zasláno: 4. 12. 2008, 23:17:18
joe
Tak potom se omlouvám já a dodávám: Tomasds nepochopil :) |
||
Časová prodleva: 15 let
|
0