Pereiti prie turinio

Informacijos ėmimas iš duomenų bazės


Rekomenduojami pranešimai

Sveiki,

Reikia paimti informacijos is duomenu bazes, bet ja pateikti kita tvarka. Turiu kodą, bet nemoku jo užbaigti taip kaip man reikia.

 

Kodas:

SELECT vardas, kodas, zinute, laikas FROM msg ORDER BY laikas desc LIMIT 3

 

Duomenų bazė:

Petras 4323 patvirtinu 26.23:45

Jonas 3454 patvirtinu 25.12:46

Antanas 3434 patvirtinu 24.19:26

Juozas 5432 patvirtinu 24.12:28

 

Ir tas kodas ima paskutinias tris eilutes, bet man reikia, kad jis pradėtų rodyti nuo seniausios (šiuo atveju nuo Antano) o paskutinė liktu naujausia (Petras). Ką reiktų tame kode pakeisti, kad taip gautūsi?

Redagavo zoltonas
Nuoroda į pranešimą
Dalintis kituose puslapiuose
Sveiki,

Reikia paimti informacijos is duomenu bazes, bet ja pateikti kita tvarka. Turiu kodą, bet nemoku jo užbaigti taip kaip man reikia.

 

Kodas:

SELECT vardas, kodas, zinute, laikas FROM msg ORDER BY laikas desc LIMIT 3

 

 

Duomenų bazė:

Petras 4323 patvirtinu 26.23:45

Jonas 3454 patvirtinu 25.12:46

Antanas 3434 patvirtinu 24.19:26

Juozas 5432 patvirtinu 24.12:28

 

Ir tas kodas ima paskutinias tris eilutes, bet man reikia, kad jis pradėtų rodyti nuo seniausios (šiuo atveju nuo Antano) o paskutinė liktu naujausia (Petras). Ką reiktų tame kode pakeisti, kad taip gautūsi?

 

 

yra sql prierašas prie query kurio db nepamenu.. bet tiesiog pamėgink parašyt 'order by -laikas'

 

:]

Redagavo infas
Nuoroda į pranešimą
Dalintis kituose puslapiuose

Vietoj desc irasyk asc, jei teisingai tavo beda supratau :-)

 

Su asc rodo nuo Juozo ir baigia Jonu. O man reiki, kad rodytu nuo Antano ir baigtu Petru (pačiu paskutiniu iš naujausių).

 

tada desc nuimk..

 

Tada vėl taspats:

Rodo nuo Juozo ir baigia Jonu. O man reiki, kad rodytu nuo Antano ir baigtu Petru (pačiu paskutiniu iš naujausių).

Nuoroda į pranešimą
Dalintis kituose puslapiuose

Su asc rodo nuo Juozo ir baigia Jonu. O man reiki, kad rodytu nuo Antano ir baigtu Petru (pačiu paskutiniu iš naujausių).

 

 

 

Tada vėl taspats:

Rodo nuo Juozo ir baigia Jonu. O man reiki, kad rodytu nuo Antano ir baigtu Petru (pačiu paskutiniu iš naujausių).

Nu tai paimk tris naujausius, o apversti listą gali jau programiškai su funkcija panašia į list.reverse() (Python'e) o tada print'inti...

Redagavo nagisa
Nuoroda į pranešimą
Dalintis kituose puslapiuose

Na, negi taip sunku. Turi savo masyvą su paskutiniais trim, bet atvirkščia tvarka, nei nori. Tarkim masyvas yra $zinutes, tai rašai $zinutes = array_reverse($zinutes) ir baigtas kriukis. Arba array_unshift imant. Visas kodas:

 

$sql = "SELECT * FROM `msg` ORDER BY `laikas` DESC LIMIT 3";
$result = mysql_query($sql);
$messages = array();

while ($row = mysql_fetch_assoc($result ))
   array_unshift($messages, $row);

//pavyzdinis panaudojimas
foreach ($messages as $item) {
   echo "{$item['vardas']}, {$item['kodas']}, {$item['zinute']}, {$item['laikas']}\n";
}

Lyg ir neprivėliau klaidų. Jei kas, klausk, bandysiu gelbėt wink.gif

Redagavo dayer
Nuoroda į pranešimą
Dalintis kituose puslapiuose

Gal būtų nesunku, tau duoti tą kodą, nes kiek ieškojau ir ką suradęs išmėginu, vistiek nesigauna kaip noriu.

db = MySQLdb.connect(host=’Demo’, user=’root’ , passwd=’adm1n’, db=’test’)
cursor = db.cursor() 
cursor.execute(“SELECT vardas, kodas, zinute, laikas FROM msg ORDER BY laikas desc LIMIT 3”)#Darome užklausą
results = list(cursor.fetchall())#Vykdome užklausą
results.reverse()#apverčiame rezultatų list'ą
for result in results:
   print result['vardas']

Čia python'e, Sąrašo apvertimui PHP turi kažkokią http://php.net/manual/en/function.array-reverse.php

Redagavo nagisa
Nuoroda į pranešimą
Dalintis kituose puslapiuose

Na, negi taip sunku. Turi savo masyvą su paskutiniais trim, bet atvirkščia tvarka, nei nori. Tarkim masyvas yra $zinutes, tai rašai $zinutes = array_reverse($zinutes) ir baigtas kriukis. Arba array_unshift imant. Visas kodas:

 

$sql = "SELECT * FROM `msg` ORDER BY `laikas` DESC LIMIT 3";
$result = mysql_query($sql);
$messages = array();

while ($row = mysql_fetch_assoc($result ))
   array_unshift($messages, $row);

//pavyzdinis panaudojimas
foreach ($messages as $item) {
   echo "{$item['vardas']}, {$item['kodas']}, {$item['zinute']}, {$item['laikas']}\n";
}

Lyg ir neprivėliau klaidų. Jei kas, klausk, bandysiu gelbėt wink.gif

 

Labai dėkoju tau. Viskas puikiai pavyko :)

Redagavo zoltonas
Nuoroda į pranešimą
Dalintis kituose puslapiuose

Prisijunkite prie diskusijos

Jūs galite rašyti dabar, o registruotis vėliau. Jeigu turite paskyrą, prisijunkite dabar, kad rašytumėte iš savo paskyros.

Svečias
Parašykite atsakymą...

×   Įdėta kaip raiškusis tekstas.   Atkurti formatavimą

  Only 75 emoji are allowed.

×   Nuorodos turinys įdėtas automatiškai.   Rodyti kaip įprastą nuorodą

×   Jūsų anksčiau įrašytas turinys buvo atkurtas.   Išvalyti redaktorių

×   You cannot paste images directly. Upload or insert images from URL.

Įkraunama...
  • Dabar naršo   0 narių

    Nei vienas registruotas narys šiuo metu nežiūri šio puslapio.

  • Prisijunk prie bendruomenės dabar!

    Uždarbis.lt nariai domisi verslo, IT ir asmeninio tobulėjimo temomis, kartu sprendžia problemas, dalinasi žiniomis ir idėjomis, sutinka būsimus verslo partnerius ir dalyvauja gyvuose susitikimuose.

    Užsiregistruok dabar ir galėsi:

    ✔️ Dalyvauti diskusijose;

    ✔️ Kurti naujas temas;

    ✔️ Rašyti atsakymus;

    ✔️ Vertinti kitų žmonių pranešimus;

    ✔️ Susisiekti su bet kuriuo nariu asmeniškai;

    ✔️ Naudotis tamsia dizaino versija;

    ir dar daugiau.

    Registracija trunka ~30 sek. ir yra visiškai nemokama.

  • Naujausios temos

  • Karštos temos

×
×
  • Pasirinkite naujai kuriamo turinio tipą...