您现在的位置: 万盛学电脑网 >> 程序编程 >> 数据库 >> 数据库综合 >> 正文

动态SQL语句使用心得

作者:佚名    责任编辑:admin    更新时间:2022-06-22

本文是一篇有关动态SQL语句使用的文章,有需要的朋友可以参考下。

动态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

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语句使用的文章,希望对大家有所帮助。