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í
×
    dnes 05:33 | IT novinky

    Samsung představil headset Galaxy XR se 4K Micro-OLED displeji, procesorem Snapdragon XR2+ Gen 2, 16 GB RAM, 256 GB úložištěm, operačním systémem Android XR a Gemini AI.

    Ladislav Hagara | Komentářů: 1
    dnes 05:22 | Nová verze

    Před konferencí Next.js Conf 2025 bylo oznámeno vydání nové verze 16 open source frameworku Next.js (Wikipedie) pro psaní webových aplikací v Reactu. Přehled novinek v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 0
    včera 23:33 | Komunita

    Sovereign Tech Fund oznámil finanční podporu následujících open source projektů: Scala, SDCC, Let's Encrypt, Servo, chatmail, Drupal, Fedify, openprinting, PHP, Apache Arrow, OpenSSL, R Project, Open Web Docs, conda, systemd a phpseclib.

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

    Bylo vydáno OpenBSD 7.8. S předběžnou podporou Raspberry Pi 5. Opět bez písničky.

    Ladislav Hagara | Komentářů: 0
    včera 05:44 | Nová verze Ladislav Hagara | Komentářů: 2
    včera 05:22 | Bezpečnostní upozornění

    Byly publikovány informace o kritické zranitelnosti v knihovně pro Rust async-tar a jejích forcích tokio-tar, krata-tokio-tar a astral-tokio-tar. Jedná se o zranitelnost CVE-2025-62518 s CVSS 8.1. Nálezci je pojmenovali TARmageddon.

    Ladislav Hagara | Komentářů: 4
    21.10. 23:15 | Nová verze

    AlmaLinux přinese s verzí 10.1 podporu btrfs. XFS bude stále jako výchozí filesystém, ale instalátor nabídne i btrfs. Více informací naleznete v oficiálním oznámení.

    Max | Komentářů: 3
    21.10. 22:33 | IT novinky

    Společnost OpenAI představila svůj vlastní webový prohlížeč ChatGPT Atlas. Zatím je k dispozici pouze na macOS.

    Ladislav Hagara | Komentářů: 0
    21.10. 14:33 | Nová verze

    Desktopové prostředí KDE Plasma bylo vydáno ve verzi 6.5 (Mastodon). Přehled novinek i s videi a se snímky obrazovek v oficiálním oznámení. Podrobný přehled v seznamu změn.

    Ladislav Hagara | Komentářů: 3
    21.10. 13:55 | IT novinky

    Rodina jednodeskových počítačů Orange Pi se rozrostla (𝕏) o Orange Pi 6 Plus.

    Ladislav Hagara | Komentářů: 13
    Jaké řešení používáte k vývoji / práci?
     (36%)
     (48%)
     (20%)
     (20%)
     (22%)
     (18%)
     (21%)
     (18%)
     (18%)
    Celkem 257 hlasů
     Komentářů: 14, poslední 14.10. 09:04
    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: 2161×
    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.