mysql_fetch_array ja foreach-silmukka

PPietari

Hei!

Olen opettelemassa php-ohjelmointia ja edessä on pieni ongelma. Olen käyttänyt while-silmukkaa tähän tyyliin:

mysql_connect($host, $user, $password) or die ('Error ' . mysql_error());
mysql_select_db($db) or die ('Error ' . mysql_error());
$result = mysql_query("SELECT * FROM data") or die(mysql_error());
//Piirtää htlm-taulukon sisältöineen
echo "";
echo "IdTyönantajaVirkaKontaktihenkilöPuhelin/Mail
Viimeinen hakupäiväPvmKommentteja";

while ($db_field = mysql_fetch_array($result)) {
echo "";
echo $db_field['id'];
echo "";
echo $db_field['työnantaja'];
echo "";
print $db_field['virka'];
echo "";
print $db_field['kontaktihenk'];
echo "";
print $db_field['puhelin'];
echo "";
print $db_field['viimeinenhakup'];
echo "";
print $db_field['date'];
echo "";
print nl2br($db_field['kommentti']);
echo "";
}
echo ""
?>

Olen miettinyt pääni puhki, kuinka saman voi tehdä foreach-silmukalla mutta en onnistu. Voiko saman tehdä foreach-silmukalla? Ihan noin vaan uteliaisuuden vuoksi.

6

655

    Vastaukset

    Anonyymi (Kirjaudu / Rekisteröidy)
    5000
    • PPietari

      Tiedoksi että näköjään palstan editori strippaa kaiken html-koodin echo-komennoista viestistä.

    • juhakorkeapudas
      • PPietari

        Se pukkaa vaan tällaista vikailmoitusta: "Warning: Invalid argument supplied for foreach()"

        Siis kun käyttää tätä foreach-silmukaa niin ei tarvitse käyttää mysql_fetch_array() -toimintoa?


      • Teman
        PPietari kirjoitti:

        Se pukkaa vaan tällaista vikailmoitusta: "Warning: Invalid argument supplied for foreach()"

        Siis kun käyttää tätä foreach-silmukaa niin ei tarvitse käyttää mysql_fetch_array() -toimintoa?

        Tervehdys!

        Aloitetaanpa siitä, ettei tuo homma hoidu tuon foreach-rakentaan avulla todellakaan noin yksinkertaisesti kuin nimerkki juhakorkeapudas antaa ymmärtää. Hänen koodinsa ei voi millään toimia, sillä tuo result-muuttuja on pelkkä resurssi, eikä varsinaisesti sisällö kuin viitteen varsinaiseen dataan. Jotta foreach-rakennetta voi käyttää, tarvitaan taulukko, jossa on kaikki sql-lausekkeella haetut rivit. Mitään valmista funktiota tämä tekemiseen ei ole. Hommaa ei muutenkaan kannata tehdä foreach-kanssa, sillä jos tietokannasta haettavaa tietoa on paljon, voi php:n memory_limit-täyttyä. Paras rakenne tietokannan tietojen käsittelyyn on tuo while, sillä ei lataan muistaa kaikkea tietoa, vaan hakee sitä rivi kerralla. Tein kuitenkin esimerkin, joka käyttää foeach-rakennetta. Tein siis itse funktion, joka hakee kaikki sql-kyselyn mukaiset samaan taulukkoon. Painotan kuitenkin, ettei tätä kannata käyttää oikeasti.

        HTML on merkitty entiteeteillä, joten sen pitäisi näkyä normaalisti.


      • Teman
        Teman kirjoitti:

        Tervehdys!

        Aloitetaanpa siitä, ettei tuo homma hoidu tuon foreach-rakentaan avulla todellakaan noin yksinkertaisesti kuin nimerkki juhakorkeapudas antaa ymmärtää. Hänen koodinsa ei voi millään toimia, sillä tuo result-muuttuja on pelkkä resurssi, eikä varsinaisesti sisällö kuin viitteen varsinaiseen dataan. Jotta foreach-rakennetta voi käyttää, tarvitaan taulukko, jossa on kaikki sql-lausekkeella haetut rivit. Mitään valmista funktiota tämä tekemiseen ei ole. Hommaa ei muutenkaan kannata tehdä foreach-kanssa, sillä jos tietokannasta haettavaa tietoa on paljon, voi php:n memory_limit-täyttyä. Paras rakenne tietokannan tietojen käsittelyyn on tuo while, sillä ei lataan muistaa kaikkea tietoa, vaan hakee sitä rivi kerralla. Tein kuitenkin esimerkin, joka käyttää foeach-rakennetta. Tein siis itse funktion, joka hakee kaikki sql-kyselyn mukaiset samaan taulukkoon. Painotan kuitenkin, ettei tätä kannata käyttää oikeasti.

        HTML on merkitty entiteeteillä, joten sen pitäisi näkyä normaalisti.

        Lisäys edelliseen viestiin:

        Kun seuraavalla kerralla teet jotain PHP:n sekä MySQL:n kanssa, niin panosta taulujen sarakkeiden nimeen, sillä nyt ne ovat suorastaan kauheat!


      • juhakorkeapudas
        Teman kirjoitti:

        Tervehdys!

        Aloitetaanpa siitä, ettei tuo homma hoidu tuon foreach-rakentaan avulla todellakaan noin yksinkertaisesti kuin nimerkki juhakorkeapudas antaa ymmärtää. Hänen koodinsa ei voi millään toimia, sillä tuo result-muuttuja on pelkkä resurssi, eikä varsinaisesti sisällö kuin viitteen varsinaiseen dataan. Jotta foreach-rakennetta voi käyttää, tarvitaan taulukko, jossa on kaikki sql-lausekkeella haetut rivit. Mitään valmista funktiota tämä tekemiseen ei ole. Hommaa ei muutenkaan kannata tehdä foreach-kanssa, sillä jos tietokannasta haettavaa tietoa on paljon, voi php:n memory_limit-täyttyä. Paras rakenne tietokannan tietojen käsittelyyn on tuo while, sillä ei lataan muistaa kaikkea tietoa, vaan hakee sitä rivi kerralla. Tein kuitenkin esimerkin, joka käyttää foeach-rakennetta. Tein siis itse funktion, joka hakee kaikki sql-kyselyn mukaiset samaan taulukkoon. Painotan kuitenkin, ettei tätä kannata käyttää oikeasti.

        HTML on merkitty entiteeteillä, joten sen pitäisi näkyä normaalisti.

        Hyvä huomio.
        Pois jäi maininta, että foreachia voi käyttää tuon whilen sisällä mutta ei yksinään.


    Ketjusta on poistettu 0 sääntöjenvastaista viestiä.

    Luetuimmat keskustelut

    1. Helena Koivu menettänyt lapsensa. Onko Mikko Koivulla oma laki?

      Voiko olla totta että äidiltä viedään lapset ja ei mitään syytä ole edes kerrottu äidille itselleen.?
      Kotimaiset julkkisjuorut
      629
      8358
    2. Hannu Pikkarainen ehdottomaan vankeuteen

      KKO tuomitsi 1 v 9 kk. Tämä ei ole Hannulle ilon päivä.
      Kotimaiset julkkisjuorut
      351
      3214
    3. Pikkunaiselle terkkuja

      Olet parasta koko maailmassa! Kaikkein ihmeellisin. Olisitpa täällä. 🧡 harmaasusi
      Ikävä
      422
      2259
    4. Kuinka paljon on

      Merkitystä seksillä kun valitset kumppania?
      Ikävä
      128
      1357
    5. Kauniit naiset

      Ketkä ne on suomussalamen kauniimpie naisie?
      Suomussalmi
      31
      1323
    6. Kuvataiteilija Johanna Oras lataa mielipiteensä Miina Äkkijyrkästä Farmilla: "Miinahan oli..."

      Oho! Johanna Oras ottaa kantaa kollega-Äkkijyrkän Farmi-puuhiin. Farmi Suomi -realityssä koettiin v. 2024 todellinen yl
      Tv-sarjat
      15
      1275
    7. Kuka on mystinen heppamies?

      Nyt tänne vinkkejä siitä kuka on Martinan seurassa viihtyvä hevosmiljonääri. On tullut jo muutamia nimiä esiin keskustel
      Kotimaiset julkkisjuorut
      109
      1201
    8. Muutto ei ratkaise mitään.

      Sielläkin on naapurit. 😉 Nähdään?
      Ikävä
      93
      1123
    9. Olet vieläkin täällä

      Tunnen energiasi. Tunnen että ajattelet minua. En aio koskaan enää ottaa sinuun yhteyttä. Voit ottaa minuun, jos itse h
      Ikävä
      65
      1075
    10. Kuinka hyvin tunnet kaivattusi?

      kuinka hyvin tunnet kaivattusi?
      Ikävä
      46
      943
    Aihe