abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 14:33 | IT novinky

    Společnost Flipper Devices oznámila Flipper One. Zcela nový Flipper postavený od nuly. Jedná se o open-source linuxovou platformu založenou na čipu Rockchip RK3576. Hledají se dobrovolníci pro pomoc s dokončením vývoje (ovladače, testování, tvorba modulů).

    Ladislav Hagara | Komentářů: 1
    dnes 14:00 | Nová verze

    Vývojáři Wine oznámili vydání verze 2.0 knihovny vkd3d pro překlad volání Direct3D na Vulkan. Přehled novinek na GitLabu.

    Ladislav Hagara | Komentářů: 0
    dnes 11:33 | Nová verze

    Společnost Red Hat oznámila vydání Red Hat Enterprise Linuxu (RHEL) 10.2 a 9.8. Vedle nových vlastností a oprav chyb přináší také aktualizaci ovladačů a předběžné ukázky budoucích technologií. Vypíchnout lze CLI AI asistenta goose. Podrobnosti v poznámkách k vydání (10.2 a 9.8).

    Ladislav Hagara | Komentářů: 0
    dnes 05:11 | Nová verze

    Organizace Apache Software Foundation (ASF) vydala verzi 30 integrovaného vývojového prostředí a vývojové platformy napsané v Javě NetBeans (Wikipedie). Přehled novinek na GitHubu. Instalovat lze také ze Snapcraftu a Flathubu.

    Ladislav Hagara | Komentářů: 0
    dnes 05:00 | Nová verze

    Byla vydána nová verze 7.0 svobodného open source redakčního systému WordPress. Kódové jméno Armstrong bylo vybráno na počest amerického jazzového trumpetisty a zpěváka Louise Armstronga (What A Wonderful World).

    Ladislav Hagara | Komentářů: 0
    dnes 04:55 | Bezpečnostní upozornění

    V Drupalu byla nalezena a opravena kritická zranitelnost SA-CORE-2026-004 (CVE-2026-9082). Útočník může provádět libovolné SQL dotazy na webech používajících databázi PostgreSQL.

    Ladislav Hagara | Komentářů: 0
    včera 14:11 | Komunita

    Richard Hughes oznámil, že službu Linux Vendor Firmware Service (LVFS) umožňující aktualizovat firmware zařízení na počítačích s Linuxem, nově sponzoruje také společnost HP.

    Ladislav Hagara | Komentářů: 3
    včera 13:33 | IT novinky

    O víkendu proběhla demopárty Outline 2026. Publikována byla prezentovaná dema. Upozornit lze na 16 bajtové, opravdu šestnáct bajtové, zvukově obrazové demo Wake Up! 16b (YouTube).

    Ladislav Hagara | Komentářů: 2
    včera 04:22 | Nová verze

    Byla vydána nová verze 9.5 multiplatformní digitální pracovní stanice pro práci s audiem (DAW) Ardour. Přehled novinek, vylepšení a oprav v poznámkách k vydání a na YouTube.

    Ladislav Hagara | Komentářů: 0
    19.5. 21:00 | IT novinky

    Dnes a zítra probíhá vývojářská konference Google I/O 2026. Sledovat lze na YouTube a na síti 𝕏 (#GoogleIO).

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (12%)
     (8%)
     (2%)
     (14%)
     (31%)
     (4%)
     (7%)
     (3%)
     (16%)
     (26%)
    Celkem 1675 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    Rozcestník

    Dotaz: Laravel - razeni podle vnorenych vztahu

    31.5.2024 16:02 Petr
    Laravel - razeni podle vnorenych vztahu
    Přečteno: 1049×
    Dobry den,

    mam nasledujici modely:
    Country hasMany cities()
    City    hasMany streets()
    Street  hasMany houses()
    
    House  belongsTo street()
    Street belongsTo city()
    City   belongsTo country()
    
    A ted se snazim do modelu Country pridat metodu houses(), ktera mi vrati pole vsech House modelu v dane Country.

    Dopracoval jsem se k tomuto:
    public function houses(): Builder
    {
        $houses = House::whereHas('street', function($query) {
            $query->whereHas('city', function($query) {
                $query->where('cities.country_id', $this->id);
            });
        });
        
        return $houses;
    }
    
    Coz mi sice funguje, ale za boha nejsem schopny prijit na to, jak ty vracene modely nejprve seradit podle cities.name, potom podle streets.name a nakonec podle houses.number

    Dekuji za pripadnou pomoc

    Odpovědi

    31.5.2024 16:17 Petr
    Rozbalit Rozbalit vše Re: Laravel - razeni podle vnorenych vztahu
    Ja se picnu! Vzdycky se mi rozsviti, az kdyz se zeptam.

    Takze reseni je napr. toto:
    public function houses(): Builder
    {
        $houses = House::leftJoin('streets', function($join) {
            $join->on('houses.street_id', 'streets.id')->leftJoin('cities', function($join) {
                $join->on('streets.city_id', 'cities.id')->where('cities.country_id', $this->id);
            });
        })
        ->orderBy('cities.name')
        ->orderBy('streets.name')
        ->orderBy('houses.number');
        return $houses;
    }
    
    Omlouvam se, za zbytecny dotaz.
    31.5.2024 16:30 Petr
    Rozbalit Rozbalit vše Re: Laravel - razeni podle vnorenych vztahu
    Takhle je to mozna jeste lepsi (vzhledem k vyslednemu SQL dotazu):
    public function houses(): Builder
    {
        $houses = House::leftJoin('streets', function($join) {
            $join->on('houses.street_id', 'streets.id');
        })
        ->leftJoin('cities', function($join) {
            $join->on('streets.city_id', 'cities.id');
        })
        ->where('cities.country_id', $this->id)
        ->orderBy('cities.name')
        ->orderBy('streets.name')
        ->orderBy('houses.number');
        
        return $houses;
    }
    

    Založit nové vláknoNahoru

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.