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

661

    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. Epäily: Oppilas puukotti kolmea Pirkkalan koululla

      Tämänhetkisen tiedon mukaan ainakin kolme oppilasta on loukkaantunut puukotuksessa Pirkkalan Vähäjärven koululla. Myös e
      Pirkanmaa
      178
      4698
    2. Jos olisit täällä

      Tosin en tiiä miks oisit. (Ja hävettää muutenkin kun ei muka muulla tavoin osaa kertoa tätäkään) Jos jollain pienellä
      Ihastuminen
      38
      2522
    3. Tämän hetken

      Terveiset kaivatullesi ⬇️
      Ikävä
      156
      2192
    4. Kesän odotuksia hyrynsalmella

      Kyllä kesällä hyrynsalmellakin on mahdollisuus osallistua kylän menoon monella tavalla . On kaunislehdon talomuseolla
      Hyrynsalmi
      16
      1719
    5. Vieläkö sä toivot

      Meidän välille jotain?
      Ikävä
      81
      1338
    6. Voi Rakas siellä

      Olet ollut mun ajatuksissa taas koko päivän. Olet ihmeellinen kertakaikkiaan ja arvostan sinua niin paljon❤️Minulla ei o
      Tunteet
      24
      1271
    7. Ohhoh! KAJ laukoi suorat sanat somessa - V-sana mainittu!

      Ohhoh! Mitäs mieltä olet tästä huumoriryhmä KAJ:sta? Bara bada bastu on kyllä aikamoinen korvamato... Lue lisää: https
      Euroviisut
      32
      1183
    8. Pirkkalan koulussa puukotus, oppilas puukotti kolmea

      Ilmeisesti tyttöjä ollut kohteena.
      Maailman menoa
      145
      1170
    9. Erika selvisi hienosti ennakkosuosikin paineista

      Hienostihan se meni. Erika jätettiin yksin, eikä häntä tuettu, oli euroviisukiusattu, silti suoriutui ensiluokkaisesti.
      Maailman menoa
      103
      945
    10. Pirre vaatii nyt karhuja ammuttavaksi

      Ylellä taas hauskaa lieksa uutista. Karhujen kannan­hoidollinen metsästys on Lieksan kaupungin mielestä välttämätöntä.
      Lieksa
      117
      877
    Aihe