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í
×
eParkomat, startup z ČR, postoupil mezi finalisty evropského akcelerátoru ChallengeUp!
Robot na pivo mu otevřel dveře k opravdovému byznysu
Internet věcí: Propojený svět? Už se to blíží...
včera 21:21 | Nová verze Ladislav Hagara | Komentářů: 0
včera 11:44 | Zajímavý projekt

Na Indiegogo byla spuštěna kampaň na podporu herní mini konzole a multimediálního centra RetroEngine Sigma od Doyodo. Předobjednat ji lze již od 49 dolarů. Požadovaná částka 20 000 dolarů byla překonána již 6 krát. Majitelé mini konzole si budou moci zahrát hry pro Atari VCS 2600, Sega Genesis nebo NES. Předinstalováno bude multimediální centrum Kodi.

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

Byla vydána verze 4.7 redakčního systému WordPress. Kódové označením Vaughan bylo vybráno na počest americké jazzové zpěvačky Sarah "Sassy" Vaughan. Z novinek lze zmínit například novou výchozí šablonu Twenty Seventeen, náhledy pdf souborů nebo WordPress REST API.

Ladislav Hagara | Komentářů: 1
6.12. 12:00 | Zajímavý projekt

Projekt Termbox umožňuje vyzkoušet si linuxové distribuce Ubuntu, Debian, Fedora, CentOS a Arch Linux ve webovém prohlížeči. Řešení je postaveno na projektu HyperContainer. Podrobnosti v často kladených dotazech (FAQ). Zdrojové kódy jsou k dispozici na GitHubu [reddit].

Ladislav Hagara | Komentářů: 24
6.12. 11:00 | Bezpečnostní upozornění

Byly zveřejněny informace o bezpečnostní chybě CVE-2016-8655 v Linuxu zneužitelné k lokální eskalaci práv. Chyba se dostala do linuxového jádra v srpnu 2011. V upstreamu byla opravena minulý týden [Hacker News].

Ladislav Hagara | Komentářů: 2
5.12. 22:00 | Komunita

Přibližně před měsícem bylo oznámeno, že linuxová distribuce SUSE Linux Enterprise Server (SLES) běží nově také Raspberry Pi 3 (dokumentace). Obraz verze 12 SP2 pro Raspberry Pi 3 je ke stažení zdarma. Pro registrované jsou po dobu jednoho roku zdarma také aktualizace. Dnes bylo oznámeno, že pro Raspberry Pi 3 je k dispozici také nové openSUSE Leap 42.2 (zprávička). K dispozici je hned několik obrazů.

Ladislav Hagara | Komentářů: 6
5.12. 06:00 | Zajímavý software

OMG! Ubuntu! představuje emulátor terminálu Hyper (GitHub) postavený na webových technologiích (HTML, CSS a JavaScript). V diskusi k článku je zmíněn podobný emulátor terminálu Black Screen. Hyper i Black Screen používají framework Electron, stejně jako editor Atom nebo vývojové prostředí Visual Studio Code.

Ladislav Hagara | Komentářů: 50
5.12. 06:00 | Zajímavý článek

I letos vychází řada ajťáckých adventních kalendářů. QEMU Advent Calendar 2016 přináší každý den nový obraz disku pro QEMU. Programátoři se mohou potrápit při řešení úloh z kalendáře Advent of Code 2016. Kalendáře Perl Advent Calendar 2016 a Perl 6 Advent Calendar přinášejí každý den zajímavé informace o programovacím jazyce Perl. Stranou nezůstává ani programovací jazyk Go.

Ladislav Hagara | Komentářů: 10
3.12. 16:24 | Nová verze

Byla vydána Mageia 5.1. Jedná se o první opravné vydání verze 5, jež vyšla v červnu loňského roku (zprávička). Uživatelům verze 5 nepřináší opravné vydání nic nového, samozřejmě pokud pravidelně aktualizují. Vydání obsahuje všechny aktualizace za posledního téměř půldruhého roku. Mageia 5.1 obsahuje LibreOffice 4.4.7, Linux 4.4.32, KDE4 4.14.5 nebo GNOME 3.14.3.

Ladislav Hagara | Komentářů: 17
3.12. 13:42 | Pozvánky

V Praze probíhá konference Internet a Technologie 16.2, volné pokračování jarní konference sdružení CZ.NIC. Konferenci lze sledovat online na YouTube. K dispozici je také archiv předchozích konferencí.

Ladislav Hagara | Komentářů: 0
Kolik máte dat ve svém domovském adresáři na svém primárním osobním počítači?
 (32%)
 (24%)
 (29%)
 (8%)
 (5%)
 (3%)
Celkem 785 hlasů
 Komentářů: 50, poslední 29.11. 15:50
Rozcestník
Reklama

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: 137×
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.