Portál AbcLinuxu, 11. května 2025 01:28

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: 199×
Odpovědět | Admin
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:


Nástroje: Začni sledovat (0) ?Zašle upozornění na váš email při vložení nového komentáře.

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
Odpovědět | | Sbalit | Link | Blokovat | Admin
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, (c) 1999-2007 Stickfish s.r.o.