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


Paging in SQL server 2005 totala antalet records

Postades av 2007-11-19 10:27:40 - Richard Österlind, i forum sql-server/msde, Tråden har 5 Kommentarer och lästs av 1091 personer

Hej!

Kör en fråga mot SQL 2005 där jag frågar ut ett begränsat antal recordsets. Jag skapar en ny temptabell with enligt senaste standard. Koden ser ut som följer:

*******************************************'
ALTER PROC [dbo].[GetCustomersByPage]

@PageSize int, @PageNumber int
AS
Declare @RowStart int
Declare @RowEnd int
if @PageNumber > 0
Begin
SET @PageNumber = @PageNumber -1
SET @RowStart = @PageSize * @PageNumber + 1;
SET @RowEnd = @RowStart + @PageSize - 1 ;

With Pages AS
( SELECT intSidID, varName,
ROW_NUMBER() OVER (order by dtmCreated) as RowNumber
FROM Sidor )
select *
from Pages
Where RowNumber >= @RowStart and RowNumber <= @RowEnd
END
************************************************
Mitt problem är att jag vill kunna får ut det totala antalet records som frågan genererar. Jag skulle vilja få till någon form av
select @totNumOfRows = count(*) From Pages.

Den skapade tabellen pages kan dock bara anropas en gång. Jag vill slippa anopa samma sökfråga 2 gånger bara för att få ut totala antalet. Har sök en hel del på google men inte kommit fram til något bra.

//Richard


Svara

Sv: Paging in SQL server 2005 totala antalet records

Postades av 2007-11-19 15:16:14 - Håkan Borneland

Så här
<code>
ALTER PROC [dbo].[GetCustomersByPage]

@PageSize int, @PageNumber int
AS

Declare @RowStart int;
Declare @RowEnd int;
Declare @totNumOfRows int;

IF (@PageNumber > 0) BEGIN
SET @PageNumber = @PageNumber - 1;
SET @RowStart = @PageSize * @PageNumber + 1;
SET @RowEnd = @RowStart + @PageSize - 1;

WITH Pages AS
(
SELECT intSidID, varName,
ROW_NUMBER() OVER (ORDER BY dtmCreated) AS RowNumber
FROM Sidor
)
SELECT *
FROM Pages
WHERE (RowNumber >= @RowStart) AND (RowNumber <= @RowEnd)
SELECT @totNumOfRows = COUNT(*) FROM Pages;
END
</code>

/Håkan


Svara

Sv:Paging in SQL server 2005 totala antalet records

Postades av 2007-11-20 10:32:34 - Richard Österlind

Det ser helt logiskt ut att man skall kunna köra en selectfråga på Pages men det går tyvärr inte. Jag testade detta tidigare. Den säger " Invalid object name 'Pages' " Den verkar slänka Pages direkt efter att man har kört första selectfrågan


Svara

Sv: Paging in SQL server 2005 totala antalet records

Postades av 2007-11-20 11:34:19 - Mikael Wedham

En CTE kan bara användas en gång, testa att använda en temptabell istället

INSERT INTO #Pages...

då kan du köra en SELECT från den.

-----------
Jag hade dessutom gjort en TABLE VALUE USER DEFINED FUNCTION istället,
då kan man köra SELECT * FROM dbo.PosterPåSidan(5)

/micke


Svara

Sv:Paging in SQL server 2005 totala antalet records

Postades av 2007-11-20 14:48:10 - Richard Österlind

Hej!

Mycket tacksam för svar!

Jag har kört in hela recordsetet i en #temptabell. Problemet är att det blir så dålig prestanda när man gör det. Det blir samma svarstider som det gamla alternativet att köra utan ROW_NUMBER. Således känns det som något fel.


Svara

Sv: Paging in SQL server 2005 totala antalet records

Postades av 2007-11-20 15:14:36 - Richard Österlind

Jag svarar på mitt eget svar. Jag städade om lite i koden och det blev väsentligt bättre prestanda. Istället för att börja med att lägga in i en #temptabell så gör jag det sist. Det var förmodligen det du menade men jag var för trög :-)

Nya koden blir då

*******************************************'
ALTER PROC [dbo].[GetCustomersByPage]

@PageSize int, @PageNumber int
AS
Declare @RowStart int
Declare @RowEnd int
if @PageNumber > 0
Begin
SET @PageNumber = @PageNumber -1
SET @RowStart = @PageSize * @PageNumber + 1;
SET @RowEnd = @RowStart + @PageSize - 1 ;

With Pages AS
( SELECT intSidID, varName,
ROW_NUMBER() OVER (order by dtmCreated) as RowNumber
FROM Sidor )
select *
INTO #Pages
FROM Pages

/*Paging resultatet*/
SELECT *
from #Pages
Where RowNumber >= @RowStart and RowNumber <= @RowEnd

/*Antalet records*/
SELECT COUNT(*) from #Pages
END
************************************************

Det fungerar mycket bättre. Tack!


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 617
27 953
271 709
5 728
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