Fetstil Fetstil Kursiv Understrykning linje färgläggning tabellverk Punktlista Nummerlista Vänster Centrerat högerställt Utfyllt Länk Bild htmlmode
  • Forum & Blog
    • Forum - översikt
      • .Net
        • asp.net generellt
        • c#
        • vb.net
        • f#
        • silverlight
        • microsoft surface
        • visual studio .net
      • databaser
        • sql-server
        • databaser
        • access
        • mysql
      • mjukvara klient
        • datorer och komponenter
        • nätverk, lan/wan
        • operativsystem
        • programvaror
        • säkerhet, inställningar
        • windows server
        • allmänt
        • crystal reports
        • exchange/outlook
        • microsoft office
      • mjukvara server
        • active directory
        • biztalk
        • exchange
        • linux
        • sharepoint
        • webbservers
        • sql server
      • appar (win/mobil)
      • programspråk
        • c++
        • delphi
        • java
        • quick basic
        • visual basic
      • scripting
        • asp 3.0
        • flash actionscript
        • html css
        • javascript
        • php
        • regular expresssion
        • xml
      • spel och grafik
        • DirectX
        • Spel och grafik
      • ledning
        • Arkitektur
        • Systemutveckling
        • krav och test
        • projektledning
        • ledningsfrågor
      • vb-sektioner
        • activeX
        • windows api
        • elektronik
        • internet
        • komponenter
        • nätverk
        • operativsystem
      • övriga forum
        • arbete karriär
        • erbjuda uppdrag och tjänster
        • juridiska frågor
        • köp och sälj
        • matematik och fysik
        • intern information
        • skrivklåda
        • webb-operatörer
    • Posta inlägg i forumet
    • Chatta med andra
  • Konto
    • Medlemssida
    • Byta lösenord
    • Bli bonsumedlem
    • iMail
  • Material
    • Tips & tricks
    • Artiklar
    • Programarkiv
  • JOBB
  • Student
    • Studentlicenser
  • KONTAKT
    • Om pellesoft
    • Grundare
    • Kontakta oss
    • Annonsering
    • Partners
    • Felanmälan
  • Logga in

Hem / Forum översikt / inlägg

Posta nytt inlägg


Intervall hantering i sql

Postades av 2003-07-28 10:45:38 - Nazgol Azizi, i forum sql-server/msde, Tråden har 4 Kommentarer och lästs av 1065 personer

Hej!
Jag har en tabell som heter Nyheter som innehåller logiskt nog nyheter. På websidan vill jag endast visa 15 nyheter åt gången. De resterande nyheterna ska man komma åt genom att klicka på länken som anger nästa intervall (1-15, 16-30, 31-45, osv). De senaste nyheterna ska komma först.

Så därför försöker jag skriva en SP (Skriven för SQL Server) som tar två argument:
* en siffra som anger start,
* en siffra som anger antal poster som ska hämtas (tex 15).

Så när användaren klickar på länken "16-30" ska jag visa 15 nyheter men det ska vara den 16:e senaste nyheten och 14 nyheter som skrevs innan den 16:e nyheten (hoppas ni förstår hur jag menar).

Mitt problem är att start och nyhetsID inte är samma sak. Så jag kan inte använda nyhets id. Hur skriver man en sån SP? Ska man använda TOP, COUNT, annat och i sånafall kan ni ge ett exempel hur sql-koden ser ut?

Mvh,
Naz


Svara

Sv: Intervall hantering i sql

Postades av 2003-07-28 11:40:24 - Anders Moldin

Hur ser din tabell ut?


Svara

Sv: Intervall hantering i sql

Postades av 2003-07-28 12:18:32 - Nazgol Azizi

Tabellen ser ut så här:

NewsID int
Title varchar(64)
Preamble varchar(8000)
Created datetime
Createdby varchar(255)

Mvh,
Naz


Svara

Sv: Intervall hantering i sql

Postades av 2003-07-28 12:35:45 - Nazgol Azizi

Jag kanske ska påpeka att det är MSSQL som spn ska skrivas i.


Svara

Sv: Intervall hantering i sql

Postades av 2003-07-28 12:43:46 - Kalle Dahlberg

För det första så kan en rad i din tabell bli större än 8060 bytes som är max, har du tänkt på det? Om man försöker lägga in mer än vad som får plats så får man ett felmeddelande.

Vad det gäller paging i SQL Server så är det lite dåligt med det tyvärr. Man kan använda sig av dubbla top satser och dynamisk sql på följande sätt:

(Jag kallar din tabell tbl1. OBS! Start är sidnumret. dvs 1 för 1-15, 2 för 16-30 osv)

create proc test @start int, @num int

AS

SET NOCOUNT ON

declare @totrows int
declare @sql varchar(1000)

select @totrows=count(*) from tbl1

select @sql='select top ' + convert(varchar, @num) + ' * from '
select @sql=@sql + ' (select top ' + convert(varchar, @totrows-((@start-1)*@num)) + ' * from tbl1 order by NewsID) as der '
select @sql=@sql + ' order by NewsID desc'

select @sql

if @totrows > ((@start-1)*@num)
exec (@sql)


Svara

Nyligen

  • 14:24 CBD regelbundet?
  • 14:23 CBD regelbundet?
  • 14:22 Har du märkt några verkliga fördel
  • 09:09 Vill du köpa medicinska tester?
  • 12:47 Vem beviljar assistansen – kommune
  • 14:17 Någon med erfarenhet av hemstädnin
  • 14:14 Bör man använda sig av en båtförme
  • 14:12 Finns det någon intressant hundblo

Sidor

  • Hem
  • Bli bonusmedlem
  • Läs artiklar
  • Chatta med andra
  • Sök och erbjud jobb
  • Kontakta oss
  • Studentlicenser
  • Skriv en artikel

Statistik

Antal besökare:
Antal medlemmar:
Antal inlägg:
Online:
På chatten:
4 569 614
27 953
271 709
483
0

Kontakta oss

Frågor runt konsultation, rådgivning, uppdrag, rekrytering, annonsering och övriga ärenden. Ring: 0730-88 22 24 | pelle@pellesoft.se

© 1986-2013 PelleSoft AB. Last Build 4.1.7169.18070 (2019-08-18 10:02:21) 4.0.30319.42000
  • Om
  • Kontakta
  • Regler
  • Cookies