动态SQL语句使用心得
程序员文章站
2023-12-15 19:20:28
在我们的项目中经常需要用到分面功能,而我以前呢用的方法现在看起来都是那麽的笨拙,当时是这样做的,每当要进行数据分页时就专们针对那个表做分页,大家别笑,以前确实好笨。呵呵,虽...
在我们的项目中经常需要用到分面功能,而我以前呢用的方法现在看起来都是那麽的笨拙,当时是这样做的,每当要进行数据分页时就专们针对那个表做分页,大家别笑,以前确实好笨。呵呵,虽然当时也有一个想法就是希望能够传入一张表进去进行操作,但那样的话编译是通不过的,因为from后面操作的是表变量,而不能是我们自定义的变量,所以当时没有深追究,现在为当时不深入学习而bs一下。
动态sql需要准备以下内容:
1、@sql 拼接后的sql语句,可以是你任意需要的sql语句如:set @sql='select * from table where id=@id' 注意此处的@sql必须且只能是ntext、nvarchar、nchar类型,如果是其它类型的话其它地方明明没有问题却会报 "过程需要类型为 'ntext/nchar/nvarchar' 的参数"这个错误。同时,如果这里需要传入表名称的话则应这样写:set @sql='select * from '+@table+'where id=@id' ,因为上面传入的值是文本类型故会报错。
2、@parameters 所拼接的sql语句里面的参数,按上面的话这里应该是:set @parameters='@id int' 同时这个参数的类型也必须且只能是ntext、nvarchar、nchar类型
3、调用:sp_executesql param1(,param2) 其中param1一般我们作为是@sql,后面的参数则是我们在@sql中的参数了,但这里要注意的是传参的时候必须是对应的:
declare @inputid int ;
set @inputid=1;
param2为:@id=@inputid;
以下是写的一个简单的通用分页,有需要可以自行修改:
alter procedure sp_pager
(
@tablename nvarchar(50), -- 表名
@returnfields nvarchar(200) = '*', -- 需要返回的列
@pagesize int = 50, -- 每页记录数
@pageindex int = 1 -- 当前页码
)
as
declare @sql nvarchar(1000)
declare @paramters nvarchar(200)
begin
set nocount on
set @sql='select '+@returnfields+' from '+@tablename+' where id>(select top 1 id from (select top '+cast(@pagesize*@pageindex as varchar)+' id from '+@tablename+ ' order by id )as a order by id desc)'
print @sql
execute sp_executesql @sql,@paramters,@columns=@returnfields
end
动态sql需要准备以下内容:
1、@sql 拼接后的sql语句,可以是你任意需要的sql语句如:set @sql='select * from table where id=@id' 注意此处的@sql必须且只能是ntext、nvarchar、nchar类型,如果是其它类型的话其它地方明明没有问题却会报 "过程需要类型为 'ntext/nchar/nvarchar' 的参数"这个错误。同时,如果这里需要传入表名称的话则应这样写:set @sql='select * from '+@table+'where id=@id' ,因为上面传入的值是文本类型故会报错。
2、@parameters 所拼接的sql语句里面的参数,按上面的话这里应该是:set @parameters='@id int' 同时这个参数的类型也必须且只能是ntext、nvarchar、nchar类型
3、调用:sp_executesql param1(,param2) 其中param1一般我们作为是@sql,后面的参数则是我们在@sql中的参数了,但这里要注意的是传参的时候必须是对应的:
复制代码 代码如下:
declare @inputid int ;
set @inputid=1;
param2为:@id=@inputid;
以下是写的一个简单的通用分页,有需要可以自行修改:
复制代码 代码如下:
alter procedure sp_pager
(
@tablename nvarchar(50), -- 表名
@returnfields nvarchar(200) = '*', -- 需要返回的列
@pagesize int = 50, -- 每页记录数
@pageindex int = 1 -- 当前页码
)
as
declare @sql nvarchar(1000)
declare @paramters nvarchar(200)
begin
set nocount on
set @sql='select '+@returnfields+' from '+@tablename+' where id>(select top 1 id from (select top '+cast(@pagesize*@pageindex as varchar)+' id from '+@tablename+ ' order by id )as a order by id desc)'
print @sql
execute sp_executesql @sql,@paramters,@columns=@returnfields
end