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í
×
    včera 01:00 | Komunita

    Debian dnes slaví 32 let. Ian Murdock oznámil vydání "Debian Linux Release" 16. srpna 1993.

    Ladislav Hagara | Komentářů: 15
    15.8. 17:44 | IT novinky

    Policisté zadrželi odsouzeného drogového dealera Tomáše Jiřikovského, který daroval ministerstvu spravedlnosti za tehdejšího ministra Pavla Blažka (ODS) bitcoiny v miliardové hodnotě, a zajistili i darovanou kryproměnu. Zadržení Jiřikovského může být podle ministerstva důležité k rozuzlení kauzy, která vypukla koncem května a vedla ke konci Blažka. Zajištění daru podle úřadu potvrzuje závěry dříve publikovaných právních

    … více »
    Ladislav Hagara | Komentářů: 8
    15.8. 13:44 | IT novinky

    Administrativa amerického prezidenta Donalda Trumpa jedná o možném převzetí podílu ve výrobci čipů Intel. Agentuře Bloomberg to řekly zdroje obeznámené se situací. Akcie Intelu v reakci na tuto zprávu výrazně posílily. Trump minulý týden označil Tana za konfliktní osobu, a to kvůli jeho vazbám na čínské společnosti, čímž vyvolal nejistotu ohledně dlouholetého úsilí Intelu o obrat v hospodaření. Po pondělní schůzce však prezident o šéfovi Intelu hovořil příznivě.

    Ladislav Hagara | Komentářů: 3
    15.8. 05:44 | IT novinky

    Společnost Purism stojící za linuxovými telefony a počítači Librem má nově v nabídce postkvantový šifrátor Librem PQC Encryptor.

    Ladislav Hagara | Komentářů: 10
    14.8. 18:00 | Nová verze

    VirtualBox, tj. multiplatformní virtualizační software, byl vydán v nové verzi 7.2. Přehled novinek v Changelogu. Vypíchnou lze vylepšené GUI.

    Ladislav Hagara | Komentářů: 0
    14.8. 14:11 | IT novinky

    Eric Migicovsky, zakladatel společnosti Pebble, v lednu oznámil, že má v plánu spustit výrobu nových hodinek Pebble s již open source PebbleOS. V březnu spustil předprodej hodinek Pebble Time 2 (tenkrát ještě pod názvem Core Time 2) za 225 dolarů s dodáním v prosinci. Včera představil jejich konečný vzhled (YouTube).

    Ladislav Hagara | Komentářů: 31
    14.8. 12:44 | Zajímavý software

    Byla oznámena nativní podpora protokolu ACME (Automated Certificate Management Environment) ve webovém serveru a reverzní proxy NGINX. Modul nginx-acme je zatím v preview verzi.

    Ladislav Hagara | Komentářů: 1
    14.8. 12:22 | Nová verze

    Vývojáři KDE oznámili vydání balíku aplikací KDE Gear 25.08. Přehled novinek i s náhledy a videi v oficiálním oznámení.

    Ladislav Hagara | Komentářů: 0
    13.8. 11:55 | IT novinky

    Společnost Perplexity AI působící v oblasti umělé inteligence (AI) podala nevyžádanou nabídku na převzetí webového prohlížeče Chrome internetové firmy Google za 34,5 miliardy dolarů (zhruba 723 miliard Kč). Informovala o tom včera agentura Reuters. Upozornila, že výše nabídky výrazně převyšuje hodnotu firmy Perplexity. Společnost Google se podle ní k nabídce zatím nevyjádřila.

    Ladislav Hagara | Komentářů: 5
    13.8. 04:33 | Bezpečnostní upozornění

    Intel vydal 34 upozornění na bezpečnostní chyby ve svých produktech. Současně vydal verzi 20250812 mikrokódů pro své procesory řešící 6 bezpečnostních chyb.

    Ladislav Hagara | Komentářů: 0
    Kolik tabů máte standardně otevřeno ve web prohlížeči?
     (52%)
     (19%)
     (4%)
     (5%)
     (2%)
     (1%)
     (1%)
     (17%)
    Celkem 406 hlasů
     Komentářů: 23, poslední 4.8. 13:01
    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: 2138×
    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.