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 + '''这句可以做到,请问这个功能到底应该如何实现?
展开
 我来答
hit_lubin
2011-05-04 · TA获得超过7889个赞
知道大有可为答主
回答量:1554
采纳率:100%
帮助的人:2017万
展开全部
是不是可以从T_SQL中取到@sql中用charindex的方式取得变量的位置,然后进行字符串截断,自己拼接,在用execute(@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 + '''这样的形式。

呵呵,不好意思,可能是我理解的不对吧,也就这么说说我的想法而已。如果不对,请不要见怪,呵呵。
richejxp
2011-05-04 · TA获得超过3106个赞
知道大有可为答主
回答量:2892
采纳率:40%
帮助的人:2300万
展开全部
你的那段语句看不明白。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
牧之卉0j1
2011-05-04 · TA获得超过1151个赞
知道大有可为答主
回答量:1689
采纳率:0%
帮助的人:1740万
展开全部
sp_executesql
具体用法看联机帮助
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 2条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式