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.
PHP ja array-järjests
10
313
Vastaukset
- 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 avullahups, 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
Porvarimediat paniikissa demareiden huiman kannatuksen vuoksi
Piti sitten keksiä "nimettömiin lähteisiin" perustuen taas joku satu. Ovat kyllä noloja, ja unohtivat sen, että vaalit435329Nyt tuli Suomen somaleista todella ikävää faktaa
sillä osa somalivanhemmista lähettää lapsiaan kotimaahansa kurinpitolaitoksiin, joissa heitä pahoinpidellään. Illan MOT4144624Häirintäkohun keskellä olevalta kansanedustajalta Jani Kokolta (sd) rajua tekstiä somessa.
https://www.is.fi/politiikka/art-2000011772322.html Ajaakohan tämä SDP:n kansanedustaja Jani Kokko oikein täysillä valoi1483849KATASTROFI - Tytti Tuppurainen itse yksi pahimmista kiusaajista!!!
STT:n lähteiden mukaan SDP:n eduskuntaryhmän puheenjohtaja Tytti Tuppurainen on käyttäytynyt toistuvasti epäasiallisesti1653194Kommentti: oikeuslaitos korvattava SDP:n johdolla
Näkisin että Suomessa tuomiovalta pitäisi olla demareiden johtoportaalla. Koska porvarimedia säestettynä persujen kirku142536Mikä siinä on ettei persuille leikkaukset käy?
On esitetty leikkauksia mm. haitallisiin maataloustukiin, kuin myös muihin yritystukiin. Säästöjä saataisiin lisäksi lei212292Huono päivä
Tänään on ollut tosi raskas päivä töissä. Tekis mieli itkeä ja huutaa. En jaksa just nyt mitään. Minä niin haluaisin ja182108Lindtman haluaa leikata Kela-korvauksista...oho!
Antti Lindtman sanoo Kauppalehdessä, että vuodesta 2028 voi tulla erittäin hankala, mikäli nykyinen hallitus ei tee riit1512032- 1251950
Typeryyttä
Se on kummallista, kun kaksi ihmistä tuntee selittämätöntä vetoa toisiinsa, mutta eivät vain pääse toistensa luokse. Mik1241479