Avatar billede Sami420 Nybegynder
03. december 2011 - 11:33 Der er 1 løsning

Bedst måde hente 10 seneste viste og opretttede annoncer

Hej alle sammen,

Jeg sidder og arbejder på annonce portal og har i den forbindelse brug for lidt hjælp.

Jeg skal have lavet to ting:
- Vise de seneste 10 oprettede annoncer.
- vise de 10 seneste VISTE annoncer


Så jeg tænkte om jeg BARE skal lave ganske almindelig joins, for at vise de annoncer direkte fra Annonce tabellen, mon det kan bliv en langsom sql søgning, hvis der er MANGE annoncer i systemet ?


og hvordan kan jeg BEDST muligt søge efter de 10 seneste viste annoncer - skal jeg gemme id på viste annoncer i applikation session variabel - og så hente annoncer udfra dem ?
Avatar billede keysersoze Guru
03. december 2011 - 11:46 #1
At vise den senest oprettede bør ikke være noget problem

SELECT TOP 10... ORDER BY id DESC

At vise de senest viste kan løses på mange måder - at benytte session- eller application-variabler lyder som en dårlig idé, sessions fungerer kun pr bruger, og application-variabler nulstilles ved fx servergenstart. Den lette måde er at gemme et tidsstempel direkte på annoncen hver gang den vises

SELECT TOP 10... ORDER BY lastshowdate DESC

men vil du have lidt mere historik med det skal du lave en tabel og gemme annonceid og tidsstempel heri og, som du selv er inde på, lave en join.

Hvis du sørger for de rette index osv vil performance ikke lide overlast - og alt afhængig af hvilken database du benytter kunne en stored procedure måske give ekstra performance.
Avatar billede Ny bruger Nybegynder

Din løsning...

Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] Web- og emailadresser omdannes automatisk til links. Der sættes "nofollow" på alle links.

Loading billede Opret Preview
Kategori
Kurser inden for grundlæggende programmering

Log ind eller opret profil

Hov!

For at kunne deltage på Computerworld Eksperten skal du være logget ind.

Det er heldigvis nemt at oprette en bruger: Det tager to minutter og du kan vælge at bruge enten e-mail, Facebook eller Google som login.

Du kan også logge ind via nedenstående tjenester