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 12:33 | IT novinky

    Na blogu Raspberry Pi byla představena rozšiřující deska Raspberry Pi AI HAT+ 2 s akcelerátorem Hailo-10 a 8 GB RAM. Na rozdíl od předchozí Raspberry Pi AI HAT+ podporuje generativní AI. Cena desky je 130 dolarů.

    Ladislav Hagara | Komentářů: 2
    dnes 12:11 | Komunita

    Wikipedie slaví 25. výročí svého založení. Vznikla 15. ledna 2001 jako doplňkový projekt k dnes již neexistující encyklopedii Nupedia. Doména wikipedia.org byla zaregistrována 12. ledna 2001. Zítra proběhne v Praze Večer svobodné kultury, který pořádá spolek Wikimedia ČR.

    Ladislav Hagara | Komentářů: 0
    dnes 04:44 | Nová verze

    Po více než dvou letech od vydání předchozí verze 2.12 byla vydána nová stabilní verze 2.14 systémového zavaděče GNU GRUB (GRand Unified Bootloader, Wikipedie). Přehled novinek v souboru NEWS a v aktualizované dokumentaci.

    Ladislav Hagara | Komentářů: 2
    dnes 02:22 | Nová verze

    Google Chrome 144 byl prohlášen za stabilní. Nejnovější stabilní verze 144.0.7559.59 přináší řadu novinek z hlediska uživatelů i vývojářů. Podrobný přehled v poznámkách k vydání. Opraveno bylo 10 bezpečnostních chyb. Vylepšeny byly také nástroje pro vývojáře (YouTube).

    Ladislav Hagara | Komentářů: 4
    dnes 01:55 | Humor

    Microsoft zveřejnil zdrojový kód XAML Studia a uvolnil ho pod MIT licencí. XAML Studio je nástroj ze světa Windows, určený pro tvorbu uživatelského rozhraní aplikací pomocí XAML (Extensible Application Markup Language). Stalo se tak zhruba po osmi letech od prvního prohlášení Microsoftu, že se tento kód chystá zveřejnit.

    NUKE GAZA! 🎆 | Komentářů: 0
    dnes 01:44 | Zajímavý projekt

    TimeCapsule, 'časová kapsle', je jazykový model trénovaný výhradně na datech z určitých míst a časových období, aby se tak napodobila autentická slovní zásoba, způsob vyjadřování a názory dané doby. Na Hugging face jsou k dispozici modely natrénované na historických textech dostupných v oblasti Londýna mezi lety 1800 až 1875.

    NUKE GAZA! 🎆 | Komentářů: 6
    včera 17:55 | Nová verze

    Radicle byl vydán ve verzi 1.6.0 s kódovým jménem Amaryllis. Jedná se o distribuovanou alternativu k softwarům pro spolupráci jako např. GitLab.

    Ladislav Hagara | Komentářů: 0
    včera 13:22 | Upozornění

    Zemřel Scott Adams, tvůrce komiksových stripů Dilbert parodujících pracovní prostředí velké firmy.

    Ladislav Hagara | Komentářů: 4
    včera 13:00 | Nová verze

    Sdružení CZ.NIC vydalo novou verzi Knot Resolveru (6.1.0). Jedná se o první vydanou stabilní verzi 6, která je nyní oficiálně preferovanou a doporučovanou verzí, namísto předešlé verze 5. Více o Knot Resolveru 6 je možné se dočíst přímo v dokumentaci.

    VSladek | Komentářů: 3
    včera 01:22 | Nová verze

    Byl vydán Linux Mint 22.3 s kódovým jménem Zena. Podrobnosti v přehledu novinek a poznámkách k vydání. Vypíchnout lze, že nástroj Systémová hlášení (System Reports) získal mnoho nových funkcí a byl přejmenován na Informace o systému (System Information). Linux Mint 22.3 bude podporován do roku 2029.

    Ladislav Hagara | Komentářů: 1
    Které desktopové prostředí na Linuxu používáte?
     (14%)
     (5%)
     (0%)
     (8%)
     (19%)
     (3%)
     (6%)
     (3%)
     (11%)
     (44%)
    Celkem 443 hlasů
     Komentářů: 12, poslední včera 21:12
    Rozcestník

    Dotaz: php a práce s velkými poli

    7.6.2013 08:39 juvi
    php a práce s velkými poli
    Přečteno: 220×
    Zdravím,

    potřebuji vytvořit jakousi rozdílovou sestavu z několika db selectů (z různých tabulek).

    1. varianta - vytvořil jsem dvojrozměrné pole a naplnil je příslušnými hodnotami. Potom našel meze polí a nakonec je v cyklu vypisuji.

    $trans = new StdClass;

    $select = ... //

    $i=0; //tak trochu zbytečné, ale chytaje se stébla...

    foreach ($select as $o_) { //cyklus nacitani pole

    $trans->id = $o_->id; $trans->rada = $o_->rada; $trans->cislo = $o_->cislo;

    $a_['zp'][$i] = $trans;

    $i++;

    //pokud tady vypisi polozku pole, je v poradku

    }

    //pokracuje podobne nacitani pole pro prvni index cp, zs, cs, ...

    // indexy a pracovni promenne

    $maxindex = array ( 'zp' => isset($a_['zp']) ? count($a_['zp']) : 0, ... );

    $cycles = max( $maxindex);

    $index = array ('zp' => 0, 'cp' => 0, 'zs' => 0, 'cs' => 0, 'zj' => 0, 'cj' => 0);

    $proc = array ('zp' => true, 'cp' => true, 'zs' => true, 'cs' => true, 'zj' => false,'cj' => false); //ridici promenne

    // a tady to velke pole zkusím vypsat

    while (max($index) < $cycles) {

    foreach ($proc as $key=>$value) {

    if ($value and $i<$maxindex[$key]) { $pole = $a_[$key][$index[$key]]; $index[$klic]++; }

    else {$proc[$key] = false; unset($pole);}

    }

    }

    Pokud si necham vypsat $pole, tak sice počet položek odpovídá, ale všechny sloupce pro všechny indexy jsou stejné, navíc sice hodnoty v jednotlivých sloupcích existují, ale v dané kombinaci v žádném řádku vstupních dat

    2. varianta - zkusil jsem jednorozměrná pole pojmenovaná prvním indexem z předchozího řešení, tedy $zp[], $cp[], ... a použil perlovský zápis, který však hlásí neexistenci proměnné:

    $$key[$i]

    takovýto zápis v PHP možný není?

    Řešení dotazu:


    Odpovědi

    7.6.2013 08:48 blondak | skóre: 36 | blog: Blondak | Čáslav
    Rozbalit Rozbalit vše Re: php a práce s velkými poli
    Podle mě je porblém hned v začátku, PHP předává třídu odkazem a vy do pole tedy ukládáte odkaz na stále stejnout třídu, takže všechny hodnoty pole jsou stejné jako právě poslední, přesunul bych tedy deklaraci $trans do cyklu.
    $select = ... //
    $i=0; //tak trochu zbytečné, ale chytaje se stébla...
    foreach ($select as $o_) { //cyklus nacitani pole
      $trans = new StdClass;
      $trans->id = $o_->id; $trans->rada = $o_->rada; $trans->cislo = $o_->cislo;
      $a_['zp'][$i] = $trans;
      $i++;
      //pokud tady vypisi polozku pole, je v poradku
    } 
    
    dál jsem to nezkoumal, nějak z toho nejsem moudrý.
    Každý problém ma své logické, snadno pochopitelné nesprávné řešení.
    7.6.2013 08:53 juvi
    Rozbalit Rozbalit vše Re: php a práce s velkými poli
    sypu si popel na hlavu a velmi děkuji za správné nakopnutí - hrabal jsem se v tom 2 dny ...
    7.6.2013 09:09 Kit
    Rozbalit Rozbalit vše Re: php a práce s velkými poli
    Myslím si, že by určitě stálo za zvážení porovnat ty dvě tabulky přímo v databázi. Určitě to bude jednodušší a rychlejší, než takové slepování v PHP.
    7.6.2013 11:06 juvi
    Rozbalit Rozbalit vše Re: php a práce s velkými poli
    Musím se přiznat, že mě to nenapadlo, Ale když nad tím uvažuji, problémů je hned několik:

    1) příliš multikriteriální porovnávání - vždy po 2 sadách dat ze 3 různých tabulek (snad by šlo vyřešit nějakou normalizovanou temporary table a složitými převody - ten uvedený kód je hodně zjednodušený - ale vidím to na postupné dolaďování. Samotné SQL je nepoužitelné, PL/SQL - neznám)

    2) průchod jednotlivých segmentů dat, přes setřídění, není příliš plynulý a vždy srovnávám jen část ze segmentu dat podle několika klíčů na základě dost složitého systému priorit - to je ta proměnná $proc - a opět to bude na postupné dopracovávání, což zase v PHP zvládnu, SQL je mimo a PL/SQL zase neznám. Ještě šikovnější by byl Perl, ale na webovém serveru ho nemusím mít ...

    Ale nakopl jste mě, aby se podíval na PL/SQL, zdá se, že tím by to šlo udělat - ten PostgreSQL má něco do sebe.

    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.