Diskuze: Nette - table does not have a primary key
Tvůrce
Zobrazeno 14 zpráv z 14.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
jedno z pravidiel ukladania udajov do databazy je, ze treba mat primary key, tym sa aj zryhli aj praca s udajmi
PK tam má u obou tabulek. S N\DB nedělám, takže si jen tipnu - nechybí ti tam cizí klíč? users_inventory.itemId REFERENCES items.id
Nevím, jak ta metoda ref() funguje, ale podle mě bude problém v tom, že
na tu tabulku item není žádná reference.
Zkus přidat cizí klíč do tabulky users_item (sloupec itemId), který bude
odkazovat na tabulku items (id).
Něco v tomto smyslu:
ALTER TABLE `users_inventory`
ADD CONSTRAINT nazev_klice
FOREIGN KEY (`itemId`)
REFERENCES `items` (`id`)
V Admineru to jde jednoduše přes "Přidat cizí klíč" v přehledu struktury tabulky.
Tak nakonec jsem se vykašlal na notORM - začínám si o tom myslet své. Celý můj problem se dal vyřešit velice jedoduše a to takto.
/*Vrátí celý inventář hráče*/
public function getPlayersInventory($playerId)
{
return $this->database->query('SELECT items.itemName, users_inventory.itemId, users_inventory.itemAmount
FROM users_inventory
LEFT JOIN items ON items.id = users_inventory.itemId
WHERE users_inventory.userId = ' . $playerId)->fetchAll();
}
Používal si špatnou metodu. Pro jednoho uživatele vybíráš více itemů (1:N) -> relace Has Many - http://doc.nette.org/…se-activerow - tudíž si měl použít related(). Metoda ref() slouží k relacím 1:1.
Ajo, už to vidím Každopádně pokud to teda vypadá takhle a máš tam nastavenou správně tu relaci, tak by to mělo fungovat. Ještě sem se nesetkal s tím, že by mi to takovou chybu vyhodilo. Jen tak pro jistotu, neměl si třeba tu tabulku items při vytvoření bez primárního klíče na id? Pak by bylo možné, že si to Nette uložilo do cache tak, že by tam ten primární klíč nebyl a proto to házelo tuhle chybu. Jinak mě vážně nenapadá, proč by to dělalo.
Nejsem si úplně jistý jak jsem to vytvářel. Cache jsem nezkoušel promazávat to je pravda no ...
Zkusil jsi tam udělat ten cizí klíč, jak jsem ti navrhoval já a jeden na
Nette fóru?
Podle mě bez cizího klíče nemá ta metoda ref() jak poznat, podle čeho má
vybrat data z druhé tabulky.
Ano, ten jsem tam dával A stejně to pořád nefungovalo.
Aha, no to je důvod, proč NDB\T nepoužívám
Zobrazeno 14 zpráv z 14.