SQL SERVER 中构建执行动态SQL语句的方法
1 :普通SQL语句可以用exec执行2:字段名,表名,数据库名之类作为变量时,必须用动态SQL--当然将字符串改成变量的形式也可declare @fname varchar(20) set @fname = 'FiledName' --设置字段名 declare @s varchar(1000) declare @s Nvarchar(1000) -- 注意此处改为nvarchar(1000) (必须为ntext或nchar哐nvarchar类型,不能是varchar类型) set @s = 'select ' + @fname + ' from tableName' 3. 输入或输出参数 set @QueryString='select * from tablename where id=@id' --id为字段名,@id为要传入的参数
set @paramstring='@id int' --设置动态语句中参数的定义的字符串
set @input_id =1 --设置需传入动态语句的参数的值为1
exec sp_executesql @querystring,@paramstring,@id=@input_id
--若有多个参数:
declare @QueryString nvarchar(1000) --动态查询语句变量(注:必须为ntext或nchar哐nvarchar类型,不能是varchar类型)
declare @paramstring nvarchar(200) --设置动态语句中的参数的字符串(注:必须为ntext或nchar哐nvarchar类型,不能是varchar类型)
declare @input_id int--定义需传入动态语句的参数的值,参数1
declare @input_name varchar(20)--定义需传入动态语句的参数的值,参数2
set @QueryString='select * from tablename where id=@id and name=@name' --id与name为字段名,@id与@name为要传入的参数
set @paramstring='@id int,@name varchar(20)' --设置动态语句中参数的定义的字符串,多个参数用","隔开
set @input_id =1 --设置需传入动态语句的参数的值为1
set @input_name='张三' --设置需传入动态语句的参数的值为"张三"
exec sp_executesql @querystring,@id=@input_id,@name=@input_name --请注意参数的顺序
--(2)输出参数
有些特殊原因,我们需要在SQL语句或者存储过程中动态创建SQL语句,然后在SQL语句或存储过程中动态来执行。 这里,微软提供了两个方法,一个是使用 Execute函数 执行方式为 Execute(@sql)来动态执行一个SQL语句,但是这里的SQL语句无法得到里面的返回结果,下面来介绍另一种方法 使用存储过程 sp_ExecuteSql 使用该存储过程,则可将动态语句中的参数返回来。 比如 执行他就会将内部创建的SQL语句的某个变量的值返回到外部调用者。 主要来源于工作中的一个偶然需要: select @HasTable=(Case when Count()>0 then 1 else 0 end) from sysobjects where id=Object_id(@TableName) and ObjectProperty(id,'IsUserTable')=1if @HasTable=0 begin set @Sql='CREATE TABLE [dbo].['+@TableName+'] ( [收费站点编号] [char] (4) COLLATE Chinese_PRC_CI_AS NOT NULL,[车道号] [tinyint] NOT NULL,[进入时间] [datetime] NOT NULL,[UID] [char] (16) COLLATE Chinese_PRC_CI_AS NOT NULL,[车牌] [varchar] (12) COLLATE Chinese_PRC_CI_AS NULL,[车型] [char] (1) COLLATE Chinese_PRC_CI_AS NULL,[识别车牌号] [varchar] (12) COLLATE Chinese_PRC_CI_AS NULL,[识别车型] [char] (1) COLLATE Chinese_PRC_CI_AS NULL,[收费金额] [money] NULL,[交易状态] [char] (1) COLLATE Chinese_PRC_CIAS NULL,[有图像] [bit] NOT NULL,[离开时间] [datetime] NULL,[速度] [float] NULL,Constraint'+' PK'+@TableName+' primary key(收费站点编号,车道号,进入时间,UID) ) ON [PRIMARY]' Execute(@Sql) end set @sql = 'select @Cnt=count() from '+@TableName+ ' where 收费站点编号='''+@收费站点编号+''' and 车道号='+cast(@车道号 as varchar(4))+' and 进入时间='''+@进入时间+''' and UID='''+@UID+'''' set @sql = @sql + ' if @Cnt=0 ' set @sql=@sql+'insert '+@TableName+' values('''+@收费站点编号+''','+cast(@车道号 as varchar(4))+','''+@进入时间+''','''+@Uid+''','''+@车牌+ 这样大家基本上就有些了解了。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |