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 05:00 | IT novinky

    Notebook NitroPad V56 od společnosti Nitrokey byl oficiálně certifikován pro Qubes OS verze 4. Qubes OS (Wikipedie) je svobodný a otevřený operační systém zaměřený na bezpečnost desktopu.

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

    Multiplatformní hororová adventura Whispering Willows je na portále GOG.com zdarma, akce trvá do 6. října.

    Fluttershy, yay! | Komentářů: 0
    včera 14:33 | Komunita

    Na čem aktuálně pracují vývojáři webového prohlížeče Ladybird (GitHub)? Byl publikován přehled vývoje za září (YouTube).

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

    Byla vydána nová verze 1.50.0 sady nástrojů pro správu síťových připojení NetworkManager. Novinkám se v příspěvku na blogu NetworkManageru věnuje Fernando F. Mancera. Vypíchnout lze podporu nastavení veth (virtual ethernet) v nmtui.

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

    Byla vydána nová verze 24.1 linuxové distribuce Manjaro (Wikipedie). Její kódové jméno je Xahea. Ke stažení je v edicích GNOME, KDE PLASMA a XFCE.

    Ladislav Hagara | Komentářů: 2
    včera 13:11 | Nová verze

    Mobilní Datovka, tj. svobodná aplikace pro přístup k datovým schránkám pro zařízení s operačním systémem iOS a Android, byla vydána v nové verzi 2.1.0. Nově je pro sestavení potřeba Qt 6.7.

    Ladislav Hagara | Komentářů: 1
    včera 12:33 | IT novinky

    Přesně před 35 lety, 3. října 1989, byla vydána počítačová hra Prince of Persia. Jejím tvůrcem je Jordan Mechner.

    Ladislav Hagara | Komentářů: 4
    2.10. 14:44 | IT novinky

    Společnost PINE64 stojící za telefony PinePhone nebo notebooky Pinebook publikovala na svém blogu zářijový souhrn novinek. Po půl roce od předchozího. Vypíchnout lze nové desky StarPro64, Oz64 a Quartz64-Zero.

    Ladislav Hagara | Komentářů: 0
    2.10. 13:44 | IT novinky Ladislav Hagara | Komentářů: 8
    2.10. 06:33 | Humor Ladislav Hagara | Komentářů: 6
    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.