abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 12:55 | Nová verze

    Byla vydána verze R14.1.2 desktopového prostředí Trinity Desktop Environment (TDE, fork KDE 3.5). Přehled novinek v poznámkách k vydání, podrobnosti v seznamu změn.

    JZD | Komentářů: 0
    včera 18:55 | IT novinky

    Dnešním dnem lze již také v Česku nakupovat na Google Store (telefony a sluchátka Google Pixel).

    Ladislav Hagara | Komentářů: 9
    včera 18:33 | IT novinky

    Apple představil (keynote) iPad Pro s čipem Apple M4, předělaný iPad Air ve dvou velikostech a nový Apple Pencil Pro.

    Ladislav Hagara | Komentářů: 2
    včera 17:11 | Nová verze

    Richard Biener oznámil vydání verze 14.1 (14.1.0) kolekce kompilátorů pro různé programovací jazyky GCC (GNU Compiler Collection). Jedná se o první stabilní verzi řady 14. Přehled změn, nových vlastností a oprav a aktualizovaná dokumentace na stránkách projektu. Některé zdrojové kódy, které bylo možné přeložit s předchozími verzemi GCC, bude nutné upravit.

    Ladislav Hagara | Komentářů: 0
    včera 13:44 | Komunita

    Free Software Foundation zveřejnila ocenění Free Software Awards za rok 2023. Vybráni byli Bruno Haible za dlouhodobé příspěvky a správu knihovny Gnulib, nováček Nick Logozzo za front-end Parabolic pro yt-dlp a tým Mission logiciels libres francouzského státu za nasazování svobodného softwaru do praxe.

    Fluttershy, yay! | Komentářů: 0
    včera 13:11 | IT novinky

    Před 10 lety Microsoft dokončil akvizici divize mobilních telefonů společnosti Nokia a pod značkou Microsoft Mobile ji zanedlouho pohřbil.

    Ladislav Hagara | Komentářů: 2
    6.5. 21:33 | Komunita

    Fedora 40 release party v Praze proběhne v pátek 17. května od 18:30 v prostorách společnosti Etnetera Core na adrese Jankovcova 1037/49, Praha 7. Součástí bude program kratších přednášek o novinkách ve Fedoře.

    Ladislav Hagara | Komentářů: 5
    6.5. 21:11 | IT novinky

    Stack Overflow se dohodl s OpenAI o zpřístupnění obsahu Stack Overflow pro vylepšení OpenAI AI modelů.

    Ladislav Hagara | Komentářů: 1
    6.5. 17:55 | Nová verze

    AlmaLinux byl vydán v nové stabilní verzi 9.4 (Mastodon, 𝕏). S kódovým názvem Seafoam Ocelot. Přehled novinek v příspěvku na blogu a v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    6.5. 17:11 | IT novinky

    Před 50 lety, 5. května 1974 v žurnálu IEEE Transactions on Communications, Vint Cerf a Bob Kahn popsali protokol TCP (pdf).

    Ladislav Hagara | Komentářů: 0
    Podle hypotézy Mrtvý Internet mj. tvoří většinu online interakcí boti.
     (63%)
     (7%)
     (14%)
     (16%)
    Celkem 139 hlasů
     Komentářů: 9, poslední včera 22:07
    Rozcestník

    Dotaz: Select jehoz vysledkem bude vicerozmerne pole

    24.4.2022 16:57 Petr
    Select jehoz vysledkem bude vicerozmerne pole
    Přečteno: 1259×
    Ahoj,

    lamu si hlavu nad timto:

    Mam tabulky Osoby, Telefony, Osoby_Telefony

    A potreboval bych udelat SELECT, ktery mi seskupi osoby se stejnym telefonnim cislem, a z nehoz mi "mysqli_fetch_assoc" udela neco takoveho:
    [telefony] => Array
        (
            [0] => Array
                (
                    [telefonni_cislo] => 111222333
                    [osoby] => Array
                        (
                            [0] => Array
                                (
                                    [id] => 1
                                    [jmeno_osoby] => Franta Koudelka
                                )
                            [1] => Array
                                (
                                    [id] => 2
                                    [jmeno_osoby] => Inzenyr Kralik
                                )
                        )
    
                )
        )
    
    Nemusi to mit presne tuhle podobu. Ale potrebuji, abych pod jednim zaznamem z tabulky Telefony, mel vsechny Osoby, ktere maji tento telefon.

    Moje hokus/pokusy selhavaji.

    Dekuji

    Řešení dotazu:


    Odpovědi

    24.4.2022 17:42 z_sk | skóre: 34 | blog: analyzy
    Rozbalit Rozbalit vše Re: Select jehoz vysledkem bude vicerozmerne pole
    Lebo asi sa to nejak rozumne a komfortne v SQL asi nedá. Máš vystúp v SQL, čo sú dáta v tabuľkách, a výstup chceš typovo niečo ako JSON.:

    <?php
    
    $lines=array();
    $lines[0][0]="123456789";
    $lines[0][1]="Meno";
    
    $lines[1][0]="123456789";
    $lines[1][1]="Meno2";
    
    $lines[2][0]="123456789";
    $lines[2][1]="Meno3";
    
    $lines[3][0]="11000";
    $lines[3][1]="Meno4";
    
    $data=array();
    foreach($lines as $record)
    {
    	$phone=$record[0];
    	$nick=$record[1];
    
    	if(isset($data["$phone"]))
    		array_push($data["$phone"], "$nick");
    	else
    		$data["$phone"]=array("$nick");
    }
    
    foreach($data as $phone => $nicks)
    {
    	echo "'$phone'\n";
    	foreach($nicks as $nick)
    		echo "\t$nick\n";
    }
    
    Výstup:
    '123456789'
    	Meno
    	Meno2
    	Meno3
    '11000'
    	Meno4
    debian.plus@protonmail.com
    24.4.2022 18:15 Petr
    Rozbalit Rozbalit vše Re: Select jehoz vysledkem bude vicerozmerne pole
    Mate pravdu, ted jsem se na stackoverflow docetl, ze:

    MySQL cannot show anything beside "rows". It can make anything you can describe as a row, but it cannot do rows within rows - it simply can't.

    Takze to budu muset opravdu resit pres PHP.

    Diky
    AraxoN avatar 29.4.2022 09:59 AraxoN | skóre: 47 | blog: slon_v_porcelane | Košice
    Rozbalit Rozbalit vše Re: Select jehoz vysledkem bude vicerozmerne pole
    Cez GROUP_CONCAT() by to asi šlo nejak znásilniť, ale spraviť to až v PHP je aj tak asi lepšie.
    27.4.2022 14:10 z_sk | skóre: 34 | blog: analyzy
    Rozbalit Rozbalit vše Re: Select jehoz vysledkem bude vicerozmerne pole
    Oprava:
     if(in_array("$phone", $data)) #riadok 22
    debian.plus@protonmail.com

    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.