--分页
create proc e_page
(
@pageIndex int,--当前页索引
@pageSize int, --一页显示几条
@allcount int output, --一共有多少条数据
@name nvarchar(20)=null --模糊查询
)
as
declare @startRow int ,@endRow int --定义两个变量
set @startRow=(@pageIndex-1)*@pageSize+1
set @endRow=@startRow+@pageSize-1
if(@name is null)
begin
select @allcount=(select count(*) from Student)
select * from (select ROW_NUMBER() over(order by (Student.ID))as bid,*from Student) as temp where temp.bid between @startRow and @endRow
end
else
begin
set @allcount=(select count(*) from Student where Student.Name like ‘%‘+@name+‘%‘)
select * from (select ROW_NUMBER() over(order by (Student.ID))as bid,*from Student where Student.Name like ‘%‘+@name+‘%‘) as temp where temp.bid between @startRow and @endRow
end
select * from Student where Student.Name like ‘%大%‘
create database Stu
use Stu
create table Student
(
ID int identity,
Name varchar(20),
Age varchar(20),
Crade varchar(20)
)
create proc e_GetList
as
begin
select * from Student
end
--查询
create proc e_GetLists
@name varchar(50),
@age varchar(50)
as
begin
declare @sql varchar(500)
set @sql = ‘select * from Student where 1=1‘
if(@name!=‘‘)
set @sql+=‘and Name like‘+‘‘‘‘+‘%‘+@name+‘%‘+‘‘‘‘;
if(@age!=‘‘)
set @sql+=‘and Age=‘‘‘+@age+‘‘‘‘;
exec(@sql)
end
exec e_GetLists ‘a‘,null
--添加
create proc e_Add
(@Name varchar(20),
@Age varchar(20),
@Crade varchar(20)
)
as
begin
insert into Student values(@Name,@Age,@Crade)
end
drop proc e_Add
--删除
create proc e_delete
(
@nid varchar(50)
)
as
begin
exec(‘delete from Student where ID in (‘+@nid+‘)‘)
end
--返填
create proc e_GetListById
(
@id int
)
as
begin
select * from Student where ID=@id
end
--修改
create proc e_update
(
@Name varchar(20),
@Age varchar(20),
@Crade varchar(20),
@ID int
)
as
begin
update Student set Name=@Name,Age=@Age,Crade=@Crade where ID=@ID
end
万能存储过程
原文:https://www.cnblogs.com/xuyuequan/p/9388643.html