abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 18:33 | IT novinky Ladislav Hagara | Komentářů: 1
    včera 22:44 | IT novinky

    Apple představil nový MacBook Pro s čipy M4, M4 Pro a M4 Max.

    Ladislav Hagara | Komentářů: 37
    včera 22:00 | Zajímavý software

    Na GOG.com běží Halloween Sale 2024. Při té příležitosti lze získat zdarma počítačovou hru Return of the Phantom.

    Ladislav Hagara | Komentářů: 0
    včera 20:22 | IT novinky

    Společnost OpenAI spustila internetový vyhledávač ChatGPT search.

    Ladislav Hagara | Komentářů: 1
    včera 14:33 | Pozvánky

    Konference OpenAlt 2024 proběhne již tento víkend 2. a 3. listopadu v prostorách FIT VUT v Brně. Začíná ale už v pátek na warm-up party ve Studentském klubu u Kachničky v 17:00. Pokud jste ještě areál FITu nenavštívili, k dispozici jsou pokyny k orientaci. Na programu je 54 přednášek a workshopů. Témata jsou od silně technických témat jako je třeba GCC nebo PostgreSQL po méně technické témata jako eGovernment, nebo třeba detailní analýzu … více »

    Ladislav Hagara | Komentářů: 5
    včera 13:23 | Nová verze

    Byla vydána nová verze 6.9 živé linuxové distribuce Tails (The Amnesic Incognito Live System), jež klade důraz na ochranu soukromí uživatelů a anonymitu. Přehled změn v příslušném seznamu. Tor Browser byl povýšen na verzi 14.0.1. Tor client na verzi 0.4.8.13. Thunderbird na verzi 115.16.0.

    Ladislav Hagara | Komentářů: 2
    včera 12:33 | Komunita

    Vývojáři free a open source synchronizačního nástroje (a p2p náhrady Dropboxu) Syncthing oznámili, že z důvodu odporu ze strany Google Play ukončují podporu OS Android. Bohužel v rámci toho zmizí i vydání Syncthing na F-Droid, který má slabší uživatelskou základnu. Syncthing je na Androidu implementován formou wrapper aplikace, která spustí Syncthing démon, vyžádá potřebná oprávnění a zpřístupní webové rozhraní démona. Ve srovnání se

    … více »
    Harvie.CZ | Komentářů: 5
    včera 01:11 | Nová verze

    V červnu 2022 bylo oznámeno, že z K-9 Mailu se stane Thunderbird pro Android. Trvalo to poněkud déle, než vývojáři předpokládali, ale včera byl první stabilní Thunderbird pro Android 8.0 vydán.

    Ladislav Hagara | Komentářů: 0
    30.10. 21:33 | Komunita

    Projekt microDMG Racer na Kickstarteru nevyšel, tak se autor rozhodl uvolnit na ESP32 postavené autíčko i ovladač jako open source.

    Ladislav Hagara | Komentářů: 6
    30.10. 13:22 | Nová verze

    Byl vydán TrueNAS SCALE 24.10 „Electric Eel“. Přehled novinek této open source storage platformy postavené na Debianu v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    Rozcestník

    Dotaz: jak uložit data do pole v php

    5.5.2011 19:32 Antonin
    jak uložit data do pole v php
    Přečteno: 2127×
    Ahoj, už vážně nevím jak na to..

    potřebuji uložit cisla do pole tak, abych pak mohl jednoduše zjistit jestli v tom poli jsou.. ale nevím jak..
    function view($a){
    $pole = array();
    $sql = mysql_query(...);
    while ($row = mysql_fetch_assoc(...){
    $s++;
    $pole[$s] = $row['id'];
    ....
    view($a){
    .....
    if(array_search($row['id'], $pole)){
    //id v poli existuje
    }else{
    // id v poli neexistuje
    }
    }
    }
    poradí někdo? Díky

    Odpovědi

    5.5.2011 22:29 Antonin
    Rozbalit Rozbalit vše Re: jak uložit data do pole v php
    Vážně nikdo nevíte?
    5.5.2011 22:57 Alf
    Rozbalit Rozbalit vše Re: jak uložit data do pole v php
    Spíš to bude tím, že dotaz je podivně sepsaný.
    if(array_search($row['id'], $pole)){
    //id v poli existuje
    }else{
    // id v poli neexistuje
    }
    Tento kód Vám přeci dělá to, co potřebujete. I když bezpečnější zápis by byl:
    if (array_search($row['id'], $pole) === false){
    //id v poli neexistuje
    } else {
    // id v poli existuje
    }
    Je to kvůli tomu, že index 0 se může vyhodnotit jako false, ale záleží na tom, jak číslujete. Viz manuál http://cz.php.net/manual/en/function.array-search.php

    Když upřesníte dotaz, určitě někdo odpoví.
    5.5.2011 23:23 Antonin
    Rozbalit Rozbalit vše Re: jak uložit data do pole v php
    Aha, tak to se omlouvám, zkusm to líp popsat.

    Potřebuji ve while uložit do nějakého pole proměnnou

    $row['id'];

    a to po každém načtení, čili když bude ve while 20 dotazu tak potřebuji

    uložit do pole 20x obsah z proměnné $row['id']; to je všechno..

    Děkuji
    6.5.2011 12:36 Alf
    Rozbalit Rozbalit vše Re: jak uložit data do pole v php
    Dotazů nebo řádků?

    Co tedy dělá tento kód? $pole[$s] = $row['id'];
    6.5.2011 13:22 Sten
    Rozbalit Rozbalit vše Re: jak uložit data do pole v php
    6.5.2011 21:40 Kit
    Rozbalit Rozbalit vše Re: jak uložit data do pole v php
    A co takhle použít asociativní pole? Vyhledávání je pak mnohem rychlejší.
    Josef Kufner avatar 7.5.2011 18:04 Josef Kufner | skóre: 70
    Rozbalit Rozbalit vše Re: jak uložit data do pole v php
    Pokud máš pár desítek záznamů v databázi a potřebuješ je procházet několikrát:
    $result = mysql_query("SELECT ... WHERE (co nejvíce omezující podmínky) ...");
    $pole = array();
    while (($row = mysql_fetch_assoc($result)) !== FALSE) {
      $pole[$row['id']] = $row;
    }
    
    if (array_key_exists($id, $pole)) {
      /* id je v poli */
    } else {
      /* id není */
    }
    
    Pokud máš hodně záznamů a potřebuješ kontrolovat jen pár záznamů, udělej několikrát tohle:
    $result = mysql_query("... WHERE id = ".intval(id)."...");
    if (($row = mysql_fetch_assoc($result)) !== FALSE) {
      /* id nalezeno, $row obsahuje záznam */
    } else {
      /* id není */
    }
    
    Pokud máš hodně záznamů a potřebuješ kontrolovat povícero záznamů:
    $id_list = array(1, 5, 12, ...);
    $result = mysql_query("SELECT COUNT(...) AS cnt "
        ."WHERE id IN (".join(',', array_map('intval', $id_list)).")");
    if ($result && $result['cnt'] == count($id_list)) {
      /* všechna id přítomna */
    } else {
      /* nějaké chybí */
    }
    
    Jinak připojovat na konec pole lze jednoduše, ale index v poli nemá žádný význam (na vypsání to stačí):
    $result = mysql_query("SELECT ...");
    $pole = array();
    while (($row = mysql_fetch_assoc($result)) !== FALSE) {
      $pole[] = $row;
    }
    
    Hello world ! Segmentation fault (core dumped)

    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.