用存储过程实现翻页

USE [CARD_DB]
GO
/****** Object:  StoredProcedure [dbo].[pr_get_star_user_list_v2]    Script Date: 03/05/2010 15:27:18 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
/*
查询STAR用户记录
最后更新:2009-11*/
ALTER PROCEDURE [dbo].[pr_get_star_user_list_v2]
@date bigint, -- 时间 分页用
@forward int, -- 为0(首页)/1是下翻页,2/3(末页)上翻页
@num int,
@type tinyint
AS
begin
if(@type =0)
begin
-- 首页
if @forward = 0
 select top (@num) type,uid,level,nickname,room_name,bank_name,bank_branch_name,bank_user_name,bank_account,tel,create_date
  from t_staruser with(nolock) order by create_date desc
-- 向下翻页
if @forward = 1
 select top (@num) type,uid,level,nickname,room_name,bank_name,bank_branch_name,bank_user_name,bank_account,tel,create_date
  from t_staruser with(nolock) where create_date < @date order by create_date desc
-- 向上翻页
if @forward = 2
 select * from (
  select top (@num) type,uid,level,nickname,room_name,bank_name,bank_branch_name,bank_user_name,bank_account,tel,create_date
   from t_staruser with(nolock) where create_date > @date order by create_date
  ) x
  order by create_date desc
  
-- 尾 页
if @forward = 3
 select * from (
  select top (@num) type,uid,level,nickname,room_name,bank_name,bank_branch_name,bank_user_name,bank_account,tel,create_date
   from t_staruser with(nolock) order by create_date
  ) x
  order by create_date desc
end
else
begin
-- 首页
if @forward = 0
 select top (@num) type,uid,level,nickname,room_name,bank_name,bank_branch_name,bank_user_name,bank_account,tel,create_date
  from t_staruser with(nolock) where type=@type order by create_date desc
-- 向下翻页
if @forward = 1
 select top (@num)type,uid,level,nickname,room_name,bank_name,bank_branch_name,bank_user_name,bank_account,tel,create_date
  from t_staruser with(nolock) where type=@type and create_date < @date order by create_date desc
-- 向上翻页
if @forward = 2
 select * from (
  select top (@num) type,uid,level,nickname,room_name,bank_name,bank_branch_name,bank_user_name,bank_account,tel,create_date
   from t_staruser with(nolock) where type=@type and create_date > @date order by create_date
  ) x
  order by create_date desc
  
-- 尾 页
if @forward = 3
 select * from (
  select top (@num) type,uid,level,nickname,room_name,bank_name,bank_branch_name,bank_user_name,bank_account,tel,create_date
   from t_staruser with(nolock) where type=@type order by create_date
  ) x
  order by create_date desc
end
end

你可能感兴趣的:(用存储过程实现翻页)