IT rekvalifikace s garancí práce. Seniorní programátoři vydělávají až 160 000 Kč/měsíc a rekvalifikace je prvním krokem. Zjisti, jak na to!
Hledáme nové posily do ITnetwork týmu. Podívej se na volné pozice a přidej se do nejagilnější firmy na trhu - Více informací.
Avatar
Jan Demel
Tvůrce
Avatar
Jan Demel:27.8.2014 16:31

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
Tvůrce
Avatar
Jan Demel:27.8.2014 16:33

Ještě ta chyba.
http://www.imagehosting.cz/?…

Nahoru Odpovědět
27.8.2014 16:33
To co se zdá být nemožné, je vždy možné.
Avatar
mkub
Tvůrce
Avatar
Odpovídá na Jan Demel
mkub:27.8.2014 18:41

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):27.8.2014 19:04

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
Aktuálně připravuji browser RPG, FB stránka - https://www.facebook.com/AlteiraCZ
Avatar
Jan Demel
Tvůrce
Avatar
Odpovídá na Martin Konečný (pavelco1998)
Jan Demel:28.8.2014 10:23

Nevím moc co máš na mysli :D

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):28.8.2014 10:31

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
Aktuálně připravuji browser RPG, FB stránka - https://www.facebook.com/AlteiraCZ
Avatar
Jan Demel
Tvůrce
Avatar
Jan Demel:31.8.2014 14:49

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:31.8.2014 14:56

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
31.8.2014 14:56
Avatar
Jan Demel
Tvůrce
Avatar
Odpovídá na hitzor
Jan Demel:31.8.2014 14:59

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:31.8.2014 15:05

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
Tvůrce
Avatar
Odpovídá na hitzor
Jan Demel:31.8.2014 15:39

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):31.8.2014 15:57

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
Aktuálně připravuji browser RPG, FB stránka - https://www.facebook.com/AlteiraCZ
Avatar
Jan Demel
Tvůrce
Avatar
Odpovídá na Martin Konečný (pavelco1998)
Jan Demel:31.8.2014 16:23

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):31.8.2014 16:37

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

Nahoru Odpovědět
31.8.2014 16:37
Aktuálně připravuji browser RPG, FB stránka - https://www.facebook.com/AlteiraCZ
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.