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 02:22 | Zajímavý software

    Hru The Legend of Zelda: Twilight Princess od společnosti Nintendo si lze nově díky projektu Dusklight (původně Dusk) a reverznímu inženýrství zahrát i na počítačích a mobilních zařízeních. Vyžadována je kopie původní hry (textury, modely, hudba, zvukové efekty, …). Ukázka na YouTube. Projekt byl zahájen v srpnu 2020.

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

    Byla vydána nová major verze 29.0 programovacího jazyka Erlang (Wikipedie) a související platformy OTP (Open Telecom Platform, Wikipedie). Detailní přehled novinek na GitHubu.

    Ladislav Hagara | Komentářů: 0
    včera 21:22 | Bezpečnostní upozornění

    Po zranitelnostech Copy Fail a Dirty Frag přichází zranitelnost Fragnesia. Další lokální eskalace práv na Linuxu. Zatím v upstreamu neopravena. Přiřazeno ji bylo CVE-2026-46300.

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

    Sovereign Tech Agency (Wikipedie) prostřednictvím svého fondu Sovereign Tech Fund podpoří KDE částkou 1 285 200 eur.

    Ladislav Hagara | Komentářů: 4
    včera 12:55 | IT novinky

    Google na včerejší akci The Android Show | I/O Edition 2026 (YouTube) představil celou řadu novinek: Gemini Intelligence, notebooky Googlebook, novou generaci Android Auto, …

    Ladislav Hagara | Komentářů: 0
    včera 12:33 | IT novinky

    Evropská komise by do léta mohla předložit návrh normy omezující používání sociálních sítí dětmi v zájmu jejich bezpečí na internetu. Prohlásila to včera předsedkyně EK Ursula von der Leyenová, podle níž řada zemí Evropské unie volá po zavedení věkové hranice pro sociální sítě. EU částečně řeší bezpečnost dětí v digitálním prostředí v již platném nařízení o digitálních službách (DSA), podle německé političky to však není dostatečné a

    … více »
    Ladislav Hagara | Komentářů: 28
    včera 04:11 | Nová verze

    Multiplatformní open source aplikace scrcpy (Wikipedie) pro zrcadlení připojeného zařízení se systémem Android na desktopu a umožňující ovládání tohoto zařízení z desktopu, byla vydána v nové verzi 4.0.

    Ladislav Hagara | Komentářů: 0
    12.5. 23:22 | Pozvánky

    Chybí vám někdo, s kým byste si popovídali o bastlení, technice, počítačích a vědě? Nechcete riskovat debatu o sportu u piva v hospodě? Pak doražte na virtuální pokec u virtuálního piva v rámci Virtuální Bastlírny organizované strahovským MacGyverem již tento čtvrtek. Možná se ptáte, co se tak může probírat? Dají se probrat slavná výročí - kromě 55 let obvodu 555 (což je mimochodem prý andělské číslo) a vzpomínky na firmu Signetics -

    … více »
    bkralik | Komentářů: 2
    12.5. 23:11 | Zajímavý software

    GTK2-NG je komunitní fork GTK 2.24 (aktuální verze je 4.22). Oznámení a diskuse v diskusním fóru Devuanu, forku Debianu bez systemd. Není to jediný fork GTK 2. Ardour je například postaven na vlastním forku GTK 2 s názvem YTK.

    Ladislav Hagara | Komentářů: 0
    12.5. 17:33 | Pozvánky

    V neděli 17. května 2026 proběhne v Českých Budějovicích první MobileLinux Hackday zaměřený na Linux v mobilech, embedded platformy a open source hardware. Po sedmi úspěšných měsíčních setkáních v Praze se akce přesouvá také do jižních Čech, aby se komunita mobilního Linuxu mohla potkat i mimo hlavní město. Akce se uskuteční v konferenčním sále Vajgar v Clarion Congress Hotelu (Pražská tř. 2306/14) se zahájením mezi 14:00 až 15:00 a … více »

    lkocman | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (13%)
     (9%)
     (2%)
     (14%)
     (31%)
     (4%)
     (7%)
     (3%)
     (16%)
     (25%)
    Celkem 1599 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    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: 223×
    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.