Diskuze: Nette - table does not have a primary key

PHP Nette Framework Nette framework Nette - table does not have a primary key

Avatar
Jan Demel
Redaktor
Avatar
Jan Demel:

Ahoj lidi. Setkal jsem se s takovým menším problémem a opravdu nevím, co mám dělat. Snažím se o to, aby se ke každému záznamu v users_inventory připojil ještě název položky z tabulky items. Když jsem konečně napsal nějaký kód, který by to mohl udělat tak mi Tracy začala nadávat, že items nemá primary key. Prosím poradili byste mi s co mám dělat ?

http://www.imagehosting.cz/?…
http://www.imagehosting.cz/?…

<?php
/*Vrátí celý inventář hráče*/
    public function getPlayersInventory($playerId)
    {
        $inventory_items = $this->database->table('users_inventory')->where('userId', $playerId);

        foreach($inventory_items as $inventory_item)
        {
            $items[] = $inventory_item->ref("items", 'itemId');
        }

        return $items;
    }
?>
Editováno 27.8.2014 16:32
Odpovědět 27.8.2014 16:31
To co se zdá být nemožné, je vždy možné.
Avatar
Jan Demel
Redaktor
Avatar
Nahoru Odpovědět 27.8.2014 16:33
To co se zdá být nemožné, je vždy možné.
Avatar
mkub
Redaktor
Avatar
Odpovídá na Jan Demel
mkub:

jedno z pravidiel ukladania udajov do databazy je, ze treba mat primary key, tym sa aj zryhli aj praca s udajmi

 
Nahoru Odpovědět 27.8.2014 18:41
Avatar
Martin Konečný (pavelco1998):

PK tam má u obou tabulek. S N\DB nedělám, takže si jen tipnu - nechybí ti tam cizí klíč? users_invento­ry.itemId REFERENCES items.id

 
Nahoru Odpovědět 27.8.2014 19:04
Avatar
Jan Demel
Redaktor
Avatar
Nahoru Odpovědět 28.8.2014 10:23
To co se zdá být nemožné, je vždy možné.
Avatar
Odpovídá na Jan Demel
Martin Konečný (pavelco1998):

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.

Editováno 28.8.2014 10:32
 
Nahoru Odpovědět 28.8.2014 10:31
Avatar
Jan Demel
Redaktor
Avatar
Jan Demel:

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();
        }
Nahoru Odpovědět 31.8.2014 14:49
To co se zdá být nemožné, je vždy možné.
Avatar
hitzor
Člen
Avatar
hitzor:

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.

 
Nahoru Odpovědět  +1 31.8.2014 14:56
Avatar
Jan Demel
Redaktor
Avatar
Odpovídá na hitzor
Jan Demel:

Jenomže jeden item měl jenom jedno jméno. :)

Nahoru Odpovědět 31.8.2014 14:59
To co se zdá být nemožné, je vždy možné.
Avatar
hitzor
Člen
Avatar
hitzor:

Ajo, už to vidím :D 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.

 
Nahoru Odpovědět 31.8.2014 15:05
Avatar
Jan Demel
Redaktor
Avatar
Odpovídá na hitzor
Jan Demel:

Nejsem si úplně jistý jak jsem to vytvářel. Cache jsem nezkoušel promazávat to je pravda no ... :)

Nahoru Odpovědět 31.8.2014 15:39
To co se zdá být nemožné, je vždy možné.
Avatar
Odpovídá na Jan Demel
Martin Konečný (pavelco1998):

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.

 
Nahoru Odpovědět 31.8.2014 15:57
Avatar
Jan Demel
Redaktor
Avatar
Odpovídá na Martin Konečný (pavelco1998)
Jan Demel:

Ano, ten jsem tam dával :) A stejně to pořád nefungovalo.

Nahoru Odpovědět 31.8.2014 16:23
To co se zdá být nemožné, je vždy možné.
Avatar
Odpovídá na Jan Demel
Martin Konečný (pavelco1998):

Aha, no to je důvod, proč NDB\T nepoužívám :D

 
Nahoru Odpovědět 31.8.2014 16:37
Děláme co je v našich silách, aby byly zdejší diskuze co nejkvalitnější. Proto do nich také mohou přispívat pouze registrovaní členové. Pro zapojení do diskuze se přihlas. Pokud ještě nemáš účet, zaregistruj se, je to zdarma.

Zobrazeno 14 zpráv z 14.