Pereiti prie turinio

Mysql informacijos apdorojimas php būdu.


Rekomenduojami pranešimai

Iš duomenų lentelės ištraukiu tam tikrus įrašus, pvz.:

 

$smth=mysql_query("SELECT * FROM zmones WHERE miestas='Kaunas'");

 

Kaip dabar nebesikišant į mysql suskaičiuoti, kiek iš tų žmonių ($smth) yra vyrai, kiek moterys?

 

O galbūt būtų OPTIMALIAU tiesiog panaudoti dvi užklausas (kuo abejoju) ?:

 

$smth1=mysql_num_rows(mysql_query("SELECT * FROM zmones WHERE miestas='Kaunas' AND sex='m'"));

$smth2=mysql_num_rows(mysql_query("SELECT * FROM zmones WHERE miestas='Kaunas' AND sex='v'"));

Nuoroda į pranešimą
Dalintis kituose puslapiuose

function search($array, $key, $value)
{
   $results = array();

   if (is_array($array))
   {
       if ($array[$key] == $value)
           $results[] = $array;

       foreach ($array as $subarray)
           $results = array_merge($results, search($subarray, $key, $value));
   }

   return $results;
}

$q=mysql_query("SELECT * FROM zmones WHERE miestas='Kaunas'");
$smth = mysql_fetch_assoc($q);

echo '<pre>'
print_r(search($smth, 'sex', 'm'));
echo '</pre>';

$moterys = count(search($smth, 'sex', 'm'));
$vyrai = count(search($smth, 'sex', 'v'));

echo 'Vyru: '.$vyrai.'<br />';
echo 'Moteru: '.$moterys.'<br />';

 

Netestinau, bet turetu veikt.

Redagavo ecash
Nuoroda į pranešimą
Dalintis kituose puslapiuose

Bijau sumeluot, tad geriau pasiskaityk pats apie innoDB engine, bet ganetinai optimalus variantas galbūt būtų nustatyt table engine ant innoDB. Tokiu atveju tavo table išsisaugos darbinėje atmintyje ir kas kartą vykdant užklausas į tam tikrą table nesikreips i db, ūžkraus viską iš darbinės atminties. Žodžiu norėjau pasakyti, kad aš tavo atvėju pasiskaityčiau apie innoDB :)

 

P.S. ecash sprendimo būdas turbūt optimaliausias :)

Redagavo luknei
Nuoroda į pranešimą
Dalintis kituose puslapiuose

Prisijunkite prie diskusijos

Jūs galite rašyti dabar, o registruotis vėliau. Jeigu turite paskyrą, prisijunkite dabar, kad rašytumėte iš savo paskyros.

Svečias
Parašykite atsakymą...

×   Įdėta kaip raiškusis tekstas.   Atkurti formatavimą

  Only 75 emoji are allowed.

×   Nuorodos turinys įdėtas automatiškai.   Rodyti kaip įprastą nuorodą

×   Jūsų anksčiau įrašytas turinys buvo atkurtas.   Išvalyti redaktorių

×   You cannot paste images directly. Upload or insert images from URL.

Įkraunama...
  • Dabar naršo   0 narių

    Nei vienas registruotas narys šiuo metu nežiūri šio puslapio.

  • Prisijunk prie bendruomenės dabar!

    Uždarbis.lt nariai domisi verslo, IT ir asmeninio tobulėjimo temomis, kartu sprendžia problemas, dalinasi žiniomis ir idėjomis, sutinka būsimus verslo partnerius ir dalyvauja gyvuose susitikimuose.

    Užsiregistruok dabar ir galėsi:

    ✔️ Dalyvauti diskusijose;

    ✔️ Kurti naujas temas;

    ✔️ Rašyti atsakymus;

    ✔️ Vertinti kitų žmonių pranešimus;

    ✔️ Susisiekti su bet kuriuo nariu asmeniškai;

    ✔️ Naudotis tamsia dizaino versija;

    ir dar daugiau.

    Registracija trunka ~30 sek. ir yra visiškai nemokama.

  • Naujausios temos

  • Karštos temos

×
×
  • Pasirinkite naujai kuriamo turinio tipą...