ORDER BY ei toimi niinkuin pitäisi...

Ongelmaapukkaa

Omalle koneelle asentamassani php/mysql:ssä order by järjestää seuraavassa koodissa menun valikon oikeaan järjestykseen. Nyt, siirtäessäni koodin palveluntarjoajalleni, menu onkin aivan väärässä järjestyksessä! Jos laitan "order by id" "order by 'order' sijaan, järjestyy valikko id:n mukaan ihan oikein. Muttei orderin.

Ehdotuksia?

Koodi:

$q = mysql_query("SELECT * FROM menu WHERE iscategory = 1 AND isactive = 1 ORDER BY 'order' ASC");
   if(!$q) print "Virhe valikossa.";


   while($row = mysql_fetch_array($q)) {
      // echo "".$row[name].""; //päävalikon nimi
      
      $q2 = mysql_query("SELECT * FROM menu WHERE iscategory = 0 AND isactive = 1 AND section = '$row[section]' ORDER BY 'order' ASC");
      if(mysql_num_rows($q2)>0) {
         while($get = mysql_fetch_array($q2)) {
            print "".$get[1]."";
         }
      } else {
         print "";
      }
   }

7

505

    Vastaukset

    Anonyymi (Kirjaudu / Rekisteröidy)
    5000
    • lkjjlkjlk

      jospa vain vaihtaisit order-kentän nimen joksikin toiseksi

      • Yritetty on

        vaihdoin order-kentän nimeksi jarjestys, ja tein tarvittavat muutokset koodiin. Edelleen järjestys on väärä, eli 1,2,3,4,5:n sijaan 5,2,1,4,3. Tämä on mystistä!


      • Sivusta....
        Yritetty on kirjoitti:

        vaihdoin order-kentän nimeksi jarjestys, ja tein tarvittavat muutokset koodiin. Edelleen järjestys on väärä, eli 1,2,3,4,5:n sijaan 5,2,1,4,3. Tämä on mystistä!

        Eikö riittä pelkkä "ORDER BY menu.order", eli miksi order on hipsukoiden sisällä? Oletko myös aivan varma siitä, ettei lajittelu toimi, eli onko order kenttien sisältö todellakin 1,2,3,4 ja 5. Kerroit että sait id:n mukaan järjestymään, niin toimiiko sekä ASC että DESC, (eli jos ne olivatkin jo järjestyksessä)?


      • Sivusta.
        Yritetty on kirjoitti:

        vaihdoin order-kentän nimeksi jarjestys, ja tein tarvittavat muutokset koodiin. Edelleen järjestys on väärä, eli 1,2,3,4,5:n sijaan 5,2,1,4,3. Tämä on mystistä!

        1. Tulostatko orderia näytölle, vai mistä päättelet ettei ORDER BY ... toimi?

        2. Koodissa kannattaisi käyttää solujen nimiä, niin tietää mitä tulostaa, esim. $get['order'] eikä vain esim. $get[1].

        3. Haussa kannattaa mainita ne kentät mitä hakee, niin tietää mitä kysely palauttaa ja missä järjestyksessä. Eli, ei pelkästään "SELECT * FROM menu WHERE ..." vaan esim. "SELECT order, name, section FROM menu WHERE ..."

        4. Toimiiko tuo koodi? Koodissasi oli kommentoitu pois kohta $row[name], jonka varmaan pitäisi olla $row['name'] (?). Siitä heräsi kysymys, eli onko _'$row[section]'_ kelvollinen lause, vai pitäisikö sen olla muotoa _'" . $row['section'] . "’_.

        5. Ohjelmassa on kaksi SQL lausetta, niin koskeeko toimimattomuus kumpaakin lausetta?

        6. Koska ohjelmassa on kaksi SQL lausetta (toinen toisen sisällä) joista kummalakin erilaiset ehdot, niin ODER BY lauseen toimattomuus on tuolla koodilla varsin vaikea todeta, (eli mistä sen tietää onko edes 1, 2, 3, 4, ja 5 oikea järjestys, kun ei tiedä mitkä taulukon arvot ovat)


      • Edellinen
        Sivusta. kirjoitti:

        1. Tulostatko orderia näytölle, vai mistä päättelet ettei ORDER BY ... toimi?

        2. Koodissa kannattaisi käyttää solujen nimiä, niin tietää mitä tulostaa, esim. $get['order'] eikä vain esim. $get[1].

        3. Haussa kannattaa mainita ne kentät mitä hakee, niin tietää mitä kysely palauttaa ja missä järjestyksessä. Eli, ei pelkästään "SELECT * FROM menu WHERE ..." vaan esim. "SELECT order, name, section FROM menu WHERE ..."

        4. Toimiiko tuo koodi? Koodissasi oli kommentoitu pois kohta $row[name], jonka varmaan pitäisi olla $row['name'] (?). Siitä heräsi kysymys, eli onko _'$row[section]'_ kelvollinen lause, vai pitäisikö sen olla muotoa _'" . $row['section'] . "’_.

        5. Ohjelmassa on kaksi SQL lausetta, niin koskeeko toimimattomuus kumpaakin lausetta?

        6. Koska ohjelmassa on kaksi SQL lausetta (toinen toisen sisällä) joista kummalakin erilaiset ehdot, niin ODER BY lauseen toimattomuus on tuolla koodilla varsin vaikea todeta, (eli mistä sen tietää onko edes 1, 2, 3, 4, ja 5 oikea järjestys, kun ei tiedä mitkä taulukon arvot ovat)

            1. Tulostatko orderia näytölle, vai mistä päättelet ettei ORDER BY ... toimi?

        Tulostan näytölle valikon. Eli valikon järjestys on väärä.

        2. Koodissa kannattaisi käyttää solujen nimiä, niin tietää mitä tulostaa, esim. $get['order'] eikä vain esim. $get[1].

        Olet oikeassa. Kohdat ovat kuitenkin kunnossa.

        3. Haussa kannattaa mainita ne kentät mitä hakee, niin tietää mitä kysely palauttaa ja missä järjestyksessä. Eli, ei pelkästään "SELECT * FROM menu WHERE ..." vaan esim. "SELECT order, name, section FROM menu WHERE ..."

        HMMMMMmmmmm..!

        4. Toimiiko tuo koodi? Koodissasi oli kommentoitu pois kohta $row[name], jonka varmaan pitäisi olla $row['name'] (?). Siitä heräsi kysymys, eli onko _'$row[section]'_ kelvollinen lause, vai pitäisikö sen olla muotoa _'" . $row['section'] . "’_.

        Kohta on kommentoitu pois tarkoituksella. Jostain syystä $row[section] ei toimi hipsukoilla, eli siis ['section'].

        5. Ohjelmassa on kaksi SQL lausetta, niin koskeeko toimimattomuus kumpaakin lausetta?

        Kyllä.

        6. Koska ohjelmassa on kaksi SQL lausetta (toinen toisen sisällä) joista kummalakin erilaiset ehdot, niin ODER BY lauseen toimattomuus on tuolla koodilla varsin vaikea todeta, (eli mistä sen tietää onko edes 1, 2, 3, 4, ja 5 oikea järjestys, kun ei tiedä mitkä taulukon arvot ovat)

        order(tai jarjestys) sisältää arvot 0,1,2,3,4,5, jokaiselle valikkopalkin linkille. Eli esim. etusivu = 0, joten sen tulisi olla ensimmäisenä. Apuva = 1, eli sen tulisi olla toinen, jne...

        Tällä hetkellä linkit yksinkertaisesti tulostuvat väärin. Ja tämä tapahtuu ainoastaan palveluntarjoajani palvelimella, omalla koneellani olevalla mysql:llä ne tulostuivat oikeassa järjestyksessä.


    • Merkit viittaavat

      Heittomerkkejä käytetään merkkijonojen ympärillä, kun taas aksenttimerkkejä (backticks) voi tarvittaessa käyttää sarakkeiden nimien ympärillä. Eli korvaa ORDER BY 'order' ASC tällä:

      ORDER BY `order` ASC

      • Hyvää apua

        Kiitos avusta! Loistavaa! Homma toimii! :)

        En tiennytkään heittomerkkien ja aksenttimerkkien eroista. No, joka päivä oppii jotain uutta. :)


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

    Luetuimmat keskustelut

    1. Kysymys muille miehille

      Onko teille varattu nainen ongelma? Mikään muu naisessa ei töki kun se että hän on varattu. Kamppailen houkutuksen kanss
      Ikävä
      130
      7152
    2. Kaipaisin nyt kosketusta

      jota ei koskaan ole ollut. Saisinpa tuntea kätesi niskallani ja silittelemässä päätäni. Sulaisin varmasti siihen.
      Ikävä
      14
      2469
    3. Imaami kysyy, miksi pojat uivat ilman valvontaa

      Kalajoen särkät ovat usean kilometrin pituiset. Siellä on kylttejä, joissa varoitetaan rannan vaaroista. Siellä ei ole
      Maailman menoa
      263
      1194
    4. Sokea "ystävälle"

      Oletko oikeasti noin sokea?
      Ikävä
      100
      1009
    5. Mansikkatiloilla hyväksikäytetään ukrainalaisia

      Työolot ovat surkeita ja palkka kelvoton. https://yle.fi/a/74-20172942
      Maailman menoa
      161
      937
    6. En ymmärrä käytöstäsi

      Se on ollut eräänlaista hyväksikäyttöä. Että seura kyllä kelpaa palstan välityksellä silloin kun ei ole parempaakaan tek
      Ikävä
      135
      879
    7. Kerrostaloihin ilmalämpöpumput

      Ulkomailla näkee paljon ilmalämpöpumppuja kerrostalojen ulkoseinissä. Mikä estää taloyhtiötä hankkimasta niitä asuntoih
      Sinkut
      69
      869
    8. Kiitoksia kaikille epäasiallisesta sisällöstä liputtaneille

      Se ylimielisyys ja epäasiallisen julkaisun jakaminen ei sitten kantanut.
      Tuusniemi
      79
      764
    9. Kirkonkylän puliveivarit

      Hieman pistää silmään nuo puliukot ja akat kirkonkylän penkeillä ja S-marketin kulmilla. Tarttis varmaan tehdä asialle j
      Karstula
      13
      723
    10. Persaukinen puolankalainen kävi kerjäämässä paitaa

      Ja lippistä. Nauratti suuresti kun katsoin. Kukahan mahtanee olla? Voipi katsoa täältä jutun. https://www.youtube.com
      Puolanka
      18
      711
    Aihe