當前位置:首頁 » 編程語言 » sql分頁置頂
擴展閱讀
webinf下怎麼引入js 2023-08-31 21:54:13
堡壘機怎麼打開web 2023-08-31 21:54:11

sql分頁置頂

發布時間: 2022-08-01 12:34:28

『壹』 php+mysql 置頂帖子分頁後每個頁面仍能置頂怎麼實現呢

唉,把要置頂的,分開兩個層來寫,把置頂的內容設置為頁的固定內容,先從資料庫里查詢出置頂的內容,把它放在頁的頂端.然後分頁的依然分下去,沒關系.是不是很簡單,呵呵

『貳』 如何使用sql語句進行分頁操作

利用SQL語句分頁要看你用的什麼資料庫。
Oracle資料庫可以使用ROWNUM或row_number(),例如:Select
*
from
(select
ROWNUM
rn,
t.*
from
table
t)
where
rn
between
11
and
20;
Select
*
from
(select
row_number()
over
(ORDER
BY
col1)
rn,
t.*
from
table
t)
where
rn
between
11
and
20;
SQLServer資料庫可以用Top或者row_number()函數,道理同上。
利用SQL分頁有局限性,就是針對不同的資料庫有不同的寫法,所以通常會在應用程序裡面做分頁通用性比較強。但是對於數據量非常龐大的應用來說,還是用SQL分頁比較適合。

『叄』 請問有沒有辦法用一條sql語句來實現置頂功能

在文章表裡有top布爾型欄位 我原來的sql語句是sql="select * from 表名 order by 時間 desc where top=true" 來顯示置頂文章,然後再用sql="select * from 表名 order by 時間 desc where top=false" 來顯示不是置頂的文章,可是這樣做的話,雖然可以實現置頂的功能,但是這樣那些置頂的文章在每一頁都會出現,並且也不便於分頁的製作,使每一頁都一樣條數的新聞沒法控制,因為置頂的新聞可能沒有也可以是多條。。
你的意思是order by後面加2個條件吧.
order by top asc, 時間 desc
其實不如分成兩個。這樣性能更好

『肆』 SQL如何實現數據分頁,要具體語句,謝謝

可以的,用存儲過程

分頁存儲過程如下

CREATE PROCEDURE GetRecordFromPage
@tblName varchar(255), -- 表名
@RetColumns varchar(1000) = '*', -- 需要返回的列,默認為全部
@Orderfld varchar(255), -- 排序欄位名
@PageSize int = 10, -- 頁尺寸
@PageIndex int = 1, -- 頁碼
@IsCount bit = 0, -- 返回記錄總數, 非 0 值則返回
@OrderType varchar(50) = 'asc', -- 設置排序類型, 非 asc 值則降序
@strWhere varchar(1000) = '' -- 查詢條件 (注意: 不要加 where)
AS

declare @strSQL varchar(1000) -- 主語句
declare @strTmp varchar(300) -- 臨時變數
declare @strOrder varchar(400) -- 排序類型

if @IsCount != 0 --執行總數統計

begin
if @strWhere != ''
set @strSQL = "select count(*) as Total from [" + @tblName + "] where " + @strWhere
else
set @strSQL = "select count(*) as Total from [" + @tblName + "]"
end

else --執行查詢操作

begin

if @OrderType != 'asc'
begin
set @strTmp = "<(select min"
set @strOrder = " order by [" + @Orderfld +"] desc"
end
else
begin
set @strTmp = ">(select max"
set @strOrder = " order by [" + @Orderfld +"] asc"
end

set @strSQL = "select top " + str(@PageSize) + " " + @RetColumns + " from ["
+ @tblName + "] where [" + @Orderfld + "]" + @strTmp + "(["
+ @Orderfld + "]) from (select top " + str((@PageIndex-1)*@PageSize) + " ["
+ @Orderfld + "] from [" + @tblName + "]" + @strOrder + ") as tblTmp)"
+ @strOrder

if @strWhere != ''
set @strSQL = "select top " + str(@PageSize) + " " + @RetColumns + " from ["
+ @tblName + "] where [" + @Orderfld + "]" + @strTmp + "(["
+ @Orderfld + "]) from (select top " + str((@PageIndex-1)*@PageSize) + " ["
+ @Orderfld + "] from [" + @tblName + "] where (" + @strWhere + ") "
+ @strOrder + ") as tblTmp) and (" + @strWhere + ") " + @strOrder

if @PageIndex = 1
begin
set @strTmp = ""
if @strWhere != ''
set @strTmp = " where (" + @strWhere + ")"

set @strSQL = "select top " + str(@PageSize) + " " + @RetColumns + " from ["
+ @tblName + "]" + @strTmp + " " + @strOrder
end
end

exec (@strSQL)

『伍』 sql語句分頁詳解

這就是一個簡單的查詢語句,一個語句分為select 與 from 之間的部分,from 與 where之間的部分 和where 後邊條件部分。
from 後跟的是表,
你說的a,b就是表名。只不過 是把(select top 20 主鍵欄位,排序欄位 from 表名 order by 排序欄位 desc)查詢的結果作為表a了。

『陸』 sql過期置頂排序

select * from table where date<getdate() order by is_pro asc,date desc union all select * from table where date>getdate() order by is_pro desc,date asc

desc asc 你自己調試下,我看暈了。應該這樣寫 沒有問題。

『柒』 c# sql 分頁使用top怎麼排序

select top 4 * --分頁大小(每頁有多少條數據)
from
(
select row_number() over (order by ID asc) as RowNumber,* from 表名
)as temp
where RowNumber > 4*(2-1)

『捌』 請教sql 置頂排序語句

使用Where關鍵字

1

Select id From table1 Where topFlag=1 order by topFlag desc, updateDate desc

『玖』 sql語句分頁和排序問題

create proc sp_page -- 資料庫名,表名,欄位名,第幾頁,每頁行數
(@dataname varchar(20),@tablename varchar(20) ,@fieldname varchar(20),@page_cur int,@page_size int)
as
declare @sqlstr varchar(200)
set @sqlstr='select top '+cast( @page_size as varchar(20))+' * from '
+@dataname+'..'+@tablename+' where '+@fieldname+' not in ( select top '
+cast((@page_cur-1)*@page_size as varchar(20))+' '+@fieldname+' from '
+@dataname+'..'+@tablename+' order by '+@tablename+'.'@fieldname')'
execute(@sqlstr)

go

--exec sp_page pubs,jobs,job_id,3,2

『拾』 sql資料庫分頁

樓主,剛剛有個問友和你問的差不多,我剛回答了他的。就直接把剛回答的復制給你看看啦。希望對你有幫助、。
要想分頁,首先得做好准備工作。你要先聲明每頁顯示多少條數據,還得獲取當前選擇的是多少頁的頁碼。有了這兩個分頁就好辦了。
sql如下:select top 10 from tableName
where (id not in(select top 20 from tableName order by Id desc)) order by Id desc
分頁需要使用到的一些動態數據如下:
每頁顯示的數量:自己定義。
總頁數:數據總條數/每頁顯示的條數
當前頁碼的計算方法:(頁碼-1)*每頁顯示的數量。比如我要瀏覽第3頁的數據,3從客戶端傳送過來後,在後台對頁碼進行處理:(3-1)*每頁顯示的數量(假如是10).算出來後的結果就是20.你在把20以參數注入的方式動態添加到上面那個20那裡就ok了。

sql中的10表示你每頁顯示的數據,這里跟10,就代表每頁顯示10條。(你可以定義一個常量作為每頁顯示的條數)
where中的20表示不包括前面的20條數據,也就是查詢出從第21條到30之間的數據。
不知道我這樣說你是否理解,其實只要理解了sql語句,分頁就很好做了。