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 01:00 | Nová verze

Oficiálně bylo vydáno Ubuntu 18.04 LTS s kódovým názvem Bionic Beaver. Tato verze s prodlouženou podporou bude podporována 5 let, tj. do dubna 2023. Přehled novinek a také odkazy na oficiální deriváty v poznámkách k vydání.

Ladislav Hagara | Komentářů: 0
včera 23:00 | Nová verze

Po osmi letech od prvního commitu byla vydána verze 1.0 webového frameworku Flask (Wikipedie) napsaného v Pythonu. Přehled novinek v oznámení o vydání. Instalovat lze z PyPI. Odstraněna byla podpora Pythonu 2.6 a 3.3.

Ladislav Hagara | Komentářů: 0
včera 16:22 | Zajímavý článek

Nadace Raspberry Pi vydala devětašedesáté číslo (pdf) anglicky psaného časopisu MagPi věnovanému Raspberry Pi a projektům postaveným na tomto jednodeskovém počítači a šesté číslo (pdf) časopisu pro kutily HackSpace věnovanému navíc 3D tisku, pájení, řezání nebo i elektronice a IoT.

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

Byl zveřejněn seznam 44 osob přijatých do programu Outreachy od 14. května do 14. srpna 2018. Cílem programu Outreachy je přitáhnout do světa svobodného a otevřeného softwaru lidi ze skupin, jež jsou ve světě svobodného a otevřeného softwaru málo zastoupeny.

Ladislav Hagara | Komentářů: 12
včera 11:44 | Nová verze

Glen MacArthur vydal verzi 2018.4.2 na Debianu založené linuxové distribuce optimalizované pro tvůrce audio a video obsahu AV Linux (Wikipedie). Podrobnosti v oznámení o vydání a v stotřicetistránkovém manuálu (pdf).

Ladislav Hagara | Komentářů: 1
25.4. 23:33 | Nová verze

Byla vydána nová stabilní verze 1.15 (1.15.1147.36) webového prohlížeče Vivaldi (Wikipedie). Z novinek lze zdůraznit možnost nastavení vlastního pozadí okna, přístup k záložkám z hlavního menu, lepší ovládatelnost v režimu celé obrazovky nebo vyřešení problémů se zvukem v HTML5. Nejnovější Vivaldi je postaveno na Chromiu 65.0.3325.183.

Ladislav Hagara | Komentářů: 0
25.4. 17:22 | Nová verze

Node.js Foundation, oficiální projekt konsorcia Linux Foundation, oznámila vydání verze 10.0.0 otevřeného multiplatformního prostředí pro vývoj a běh síťových aplikací napsaných v JavaScriptu Node.js (Wikipedie). Verze 10 se v říjnu stane novou aktivní LTS verzí. Podpora je plánována do dubna 2021.

Ladislav Hagara | Komentářů: 0
25.4. 15:33 | Nová verze

Neal Cardwell ze společnosti Google oznámil zveřejnění verze 2.0 nástroje pro testování síťového stacku packetdrill. Jde o souhrnné vydání změn z interního vývoje od roku 2013.

Michal Kubeček | Komentářů: 0
25.4. 13:22 | Zajímavý software

Microsoft na svém blogu oznámil, že správce knihoven pro C++ Vcpkg (VC++ Packaging Tool) lze nově používat také na Linuxu a macOS. Aktuálně je pro Linux k dispozici více než 350 knihoven [reddit].

Ladislav Hagara | Komentářů: 1
25.4. 12:44 | Komunita

Byly zveřejněny exploity na Nintendo Switch a platformu Tegra X1: Fusée Gelée a ShofEL2. Jejich zneužití nelze zabránit softwarovou aktualizací. Na druhou stranu exploity umožní na Nintendo Switch snadno a rychle nainstalovat Linux, viz. ukázka na YouTube. Jenom je potřeba sáhnout na hardware.

Ladislav Hagara | Komentářů: 0
Používáte na serverech port knocking?
 (3%)
 (7%)
 (47%)
 (26%)
 (18%)
Celkem 388 hlasů
 Komentářů: 29, poslední 5.4. 12:25
    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: 144×
    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.