PHP ja array-järjests

Anonyymi

Ongelma ratkottavaksi (lyhennetty esimerkki):
Tietokannassa on tuotteita ja niiden hintoja.
Luetaan useita rivejä queryllä "SELECT id, hinta, määrä WHERE..."
Miten nämä tulokset saisi arvon mukaiseen järjestykseen (hinta*määrä) ja huomioituna vain ne, joissa on arvo yli x? ORDER BY toimii vain yhden sarakkeen mukaan, en ole saanut huomioimaan laskutoimitusta.

10

303

    Vastaukset

    Anonyymi (Kirjaudu / Rekisteröidy)
    5000
    • Anonyymi

      Onnistuin ORDER BY huomioi laskutoimituksen. Nyt olisi kuitenkin tuo laskutoimitus hieman mutkikkaampi ja se on funktiona. "SELECT id, hinta, määrä, rahti, korko WHERE... ORDER BY hinnoittelu($hinta, $määrä, $rahti, $korko)"
      Tämä taitaa jo olla tekemätön paikka.

      • Anonyymi

        Jos tuo on PHP funktio niin sitä ei tietenkään voi kyselyssä käyttää. Tulee mieleen kaksi tapaa ratkaista tämä:

        1) lisää funktio itse tietokantaan jolloin sitä voi käyttää (tämä edellyttää että voit kirjoittaa funktion SQL:llä)
        2) jätä ORDER BY pois kyselystä ja järjestä saadut rivit erikseen PHP funktion avulla


      • Anonyymi
        Anonyymi kirjoitti:

        Jos tuo on PHP funktio niin sitä ei tietenkään voi kyselyssä käyttää. Tulee mieleen kaksi tapaa ratkaista tämä:

        1) lisää funktio itse tietokantaan jolloin sitä voi käyttää (tämä edellyttää että voit kirjoittaa funktion SQL:llä)
        2) jätä ORDER BY pois kyselystä ja järjestä saadut rivit erikseen PHP funktion avulla

        hups, tarvitseeko WHERE myös tuota funktiota? Sitten menee hankalammaksi koska vaihtoehdossa 2) pitää jättää myös WHERE pois, lukea KAIKKI rivit kyselyssä, sitten järjestää PHP:llä ja jättää pois ne joissa arvo on liian pieni.

        Jos rivejä on liikaa että ne voisi kaikki lukea niin sitten vaihtoehto 1) on ainoa mahdollinen, eli sinun pitää kirjoittaa tuo funktio PHP:n sijasta SQL:llä.


      • Anonyymi

        Kunka syvälle voi kauhan tunekea ennenkö tulee asiaa exsoteen.


      • Anonyymi
        Anonyymi kirjoitti:

        Kunka syvälle voi kauhan tunekea ennenkö tulee asiaa exsoteen.

        Hajooko hanuri?


    • Anonyymi

      Kertolaskun voi ujuttaa kyselyyn vaikkapa näin

      SELECT id, hinta, määrä, hinta * määrä AS arvo FROM taulu ORDER BY arvo DESC

      ja saada kyselyn tulos arvon mukaisesti suuruusjärjestyksessä.

    • Anonyymi

      Hyvä, tämä viimeinen oli se mitä hain! Thanks.

    • Anonyymi

      EI ihan ollutkaan joka kohtaan, kun hieman mutkikkaampi kaava ei SQL-kyselyssä toimikaan.
      Jospa tekisin niin, että luen id:n ja pakolliset tiedot WHERE-ehdon täyttävistä.
      Laitan ne arrayhin ja samalla lasken kaavan arrayhin mukaan.

      Tästä tulee monirivinen array, enkä ihan osaa tehdä sitä kyselyn tuloksista. Vinkki tai linkki nopeuttaisi tekemistä kovasti.

      • Anonyymi

        "Hieman mutkikkaampi kaava" ei tarjoa ulkopuolisille mahdollisuutta ottaa asiaan enempi kantaa. Yleisesti voi toki mainita että jos yhtä tietokannan kyselyä ei saa taipumaan muotoon millä ongelma ratkeaisi, niin näkymiä (VIEW) lisäämällä ja erilaisia JOINeja hyödyntämällä mahdollisuudet paranee oleellisesti.

        Kysymys on PHP-osiossa, joten kannasta saatavan datan lopullinen muokkaus ja filtteröinti tarpeeseen sopivaksi hoituu sitten PHP:n omin keinoin.


    • Anonyymi

      Moiulotteinenkin array onnistui ja homma on pulkassa ja kauppa käy taas.

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

    Luetuimmat keskustelut

    1. Mitä aiot tehdä uudenvuoden aattona

      Mitä olet suunnitellut tekeväsi uudenvuoden aattona ja aiotko ensi vuonna tehdä jotain muutoksia tai uudenvuoden lupauks
      Sinkut
      202
      4404
    2. Marin sitä, Marin tätä, yhyy yhyy, persut jaksaa vollottaa

      On nuo persut kyllä surkeaa porukkaa. Edelleen itkevät jonkun Marinin perään, vaikka itse ovat tuhonneet Suomen kansan t
      Maailman menoa
      58
      3142
    3. Väestönsiirtoa itään?

      Ano "the Russo" Turtiainen sai poliittisen turvapaikan Venäjältä. Pian lähtee varmaan Nazima Nuzima ja Kiljusen väki per
      Helsinki
      88
      1737
    4. Muistattekos kuinka persujen Salainen Akentti kävi Putinin leirillä

      Hakemassa jamesbondimaista vakoiluoppia paikan päällä Venäjällä? Siitä ei edes Suomea suojeleva viranomainen saanut puhu
      Maailman menoa
      18
      1316
    5. Ikävä sinua..

      Kauan on aikaa kulunut ja asioita tapahtunut. Mutta sinä M-ies olet edelleen vain mielessäni. En tiedä loinko sinusta va
      Ikävä
      12
      1314
    6. Vuoden luetuimmat: Mikä on Pelle Miljoonan taiteilijaeläkkeen suuruus?

      Pelle Miljoonan eläkkeen suuruus kiinnosti lukijoita tänä vuonna. Artikkeli on Suomi24 Viihteen luetuimpia juttuja v. 20
      Suomalaiset julkkikset
      23
      1117
    7. Lindtmanin pääministeriys lähenee päivä päivältä

      Suomen kansan kissanpäivät alkavat siitä hetkestä, kun presidentti Stubb on tehnyt nimityksen. Ainoastaan ylin tulodesi
      Maailman menoa
      10
      1101
    8. Kuumalle kaivatulle tiedoksi

      Tykkään susta!
      Ikävä
      49
      1075
    9. Riikka Purra sanoo, että sietokykyni vittumaisiin ihmisiin alkaa olla lopussa.

      https://www.iltalehti.fi/politiikka/a/be8f784d-fa24-44d6-b59a-b9b83b629b28 Riikka Purra sanoo medialle suorat sanat vitt
      Maailman menoa
      247
      1073
    10. Nyt musta tuntuu

      Et alat päästämään kokonaan irti..
      Ikävä
      49
      976
    Aihe