SQL 动态查询问题
Declare@SqlAsNvarChar(4000);Declare@dateSAsvarchar(10);set@dateS='2011-05-01'Set@Sql=...
Declare @Sql As NvarChar(4000);
Declare @dateS As varchar(10);
set @dateS = '2011-05-01'
Set @Sql = (select T_sql from DataDB.dbo.Sql where id=1)
--Set @Sql = N'select * from table where date >= ''' + @dateS + '''
ExeCute (@Sql)
想实现这样一个功能,将动态查询语句,放入Sql表中的T_sql字段,字段是类型是NvarChar(4000),再用查询语句将其查出来,然后赋给@Sql这个变量,然后用ExeCute执行,但是如果这个字段的值,也就是查询语句中包含了变量,如果用print打出来看一下会发现,语句不能将变量变成实际值,但是直接使用Set @Sql = N'select * from table where date >= ''' + @dateS + '''这句可以做到,请问这个功能到底应该如何实现? 展开
Declare @dateS As varchar(10);
set @dateS = '2011-05-01'
Set @Sql = (select T_sql from DataDB.dbo.Sql where id=1)
--Set @Sql = N'select * from table where date >= ''' + @dateS + '''
ExeCute (@Sql)
想实现这样一个功能,将动态查询语句,放入Sql表中的T_sql字段,字段是类型是NvarChar(4000),再用查询语句将其查出来,然后赋给@Sql这个变量,然后用ExeCute执行,但是如果这个字段的值,也就是查询语句中包含了变量,如果用print打出来看一下会发现,语句不能将变量变成实际值,但是直接使用Set @Sql = N'select * from table where date >= ''' + @dateS + '''这句可以做到,请问这个功能到底应该如何实现? 展开
3个回答
展开全部
是不是可以从T_SQL中取到@sql中用charindex的方式取得变量的位置,然后进行字符串截断,自己拼接,在用execute(@sql)来执行?
因为T_SQL中取出来后,变量也就不是原有的变量了,而是都进入了一个字符串当中,所以再也不能当做变量使用了。你只能把这个变量找出来,然后通过字符串截断的方式把前后截出来,然后把你真正的变量拼到上面。
因为T_SQL中取出来后,变量也就不是原有的变量了,而是都进入了一个字符串当中,所以再也不能当做变量使用了。你只能把这个变量找出来,然后通过字符串截断的方式把前后截出来,然后把你真正的变量拼到上面。
追问
拼接这种方法无法去找变量啊。。这个很麻烦的。。而且语言的重用性不大了。。
有没有一个什么转换函数。。可以强制转换这个nvarchar类型字段。。在它赋值给@SQL变量的时候成为一个语句类变量转变为变量值后的完整语句呢?
追答
拼接的方法不是找变量,而是找你T_SQL这个字段里面取出来存在@sql这个串里面的字符串值'@dateS',因为你存在里面取出来到@sql之后,这个@dateS已经不再是变量了,而是一个字符串了。
不知道是不是我理解错了,我的理解是,您的T_sql这个字段可能会有一个字符串,而这个串的值就是'select * from table where date >= ''' + @dateS + '''这样一个动态查询的语句,可是您要知道,这个t_sql的值当中,@dates已经不是变量了,而是这个t_sql字段中的一部分字符串而已。
所以我的想法是先取出t_sql的值,然后判断'@dates’这个串的位置,判断好了之后,截掉,然后在把你的变量使用变量的拼接形式拼进去。变成N'select * from table where date >= ''' + @dateS + '''这样的形式。
呵呵,不好意思,可能是我理解的不对吧,也就这么说说我的想法而已。如果不对,请不要见怪,呵呵。
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询