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

527

    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. Lataus pakkaskelissä

      En olisi koskaan ostanut sähköautoa jos olisin tajunnut että ne eivät lataa pakkasissa suurteholatauksella vaan istut tu
      Hybridi- ja sähköautot
      177
      6764
    2. Kun väestö ikääntyy ja veronmaksajat vähenee, mitä sitten vasemmistolaiset?

      Maahanmuutto ei vaan ole ratkaisu väestön ikääntymiseen. Maahanmuutto lykkää ja hidastaa väestön ikääntymistä ja työv
      Maailman menoa
      115
      3204
    3. Miksei Trump ole kiinnostunut Suomen valloittamisesta?

      Täällähän on enemmän turvetta kuin Norjalla öljyä. Eikö Ttump ole turvenuija?
      Maailman menoa
      104
      1895
    4. Tiedän ettei

      Meistä mitään tule. Toinen oli sinulle tärkeämpi
      Ikävä
      19
      1689
    5. Aktivistinainen pysäytti ICE-agentin luodin päällään USA:ssa!

      Video ampumistilanteesta: https://edition.cnn.com/2026/01/07/us/video/ice-shooting-minneapolis-digvid "Media: ICE:n am
      Maailman menoa
      64
      1676
    6. Oikeistopuolueiden kannatus vain 37,8 %, vasemmiston 43,0 %

      Keskustaan jää 17,4 prosenttia ja loput ovat sitten mitä ovat. Mutta selvästikin Suomen kansa on vasemmalle kallellaan.
      Maailman menoa
      1
      1569
    7. "Mitä sä nainen tuot sitten pöytään" ?

      Jos mies provaidaa ja suojelee... Pitääkö miesten kysyä tuollaisia?
      Ikävä
      38
      1556
    8. Ekologinen kommunismi tulee voittamaan fossiilikapitalismin

      Kiina on mahtitekijä uusiutuvien energialähteiden kehityksessä, ja Trump osoitus viimeisestä öljyn perään itkemisestä, m
      Maailman menoa
      15
      1363
    9. Kyllä mä suren

      Sitä että mikään ei ole kuten ennen. Ei niitä hetkiä ja katseita. Toisaalta keho lepää eikä enää tarvitse sitä tuskaa ko
      Ikävä
      11
      1320
    10. Laitetaan nyt kirjaimet kohdilleen

      kuka rakastaa ja ketä ?
      Ikävä
      65
      1265
    Aihe