免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3378 | 回复: 2
打印 上一主题 下一主题

请教VB中的EVAL函数在SQL中有对应的函数吗? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2006-04-12 15:46 |只看该作者 |倒序浏览
create procedure aaa
@a varchar(9)
as
if EVAL(@A)
drop table mybiao
GO


我想要这样的结果,用  execute  aaa \"字符串表达式\"  来调用该存储过程,输入一个表达式,如:\"1+1=2\",要是为“真”,就删除表“mybiao”。但上述存储过程不能创建,请教用哪个函数来代替EVAL可实现这种过程,谢谢!

论坛徽章:
0
2 [报告]
发表于 2006-04-12 18:22 |只看该作者
Create procedure aaa
@a varchar(9)
as
Declare @SQL Varchar(200)
Select @SQL = \'Select 1 Where \' + @a

Select 1 ID Into #a Where 1 = 2

Insert Into #a
Execute (@SQL)

If Exists(Select 1 From #a Where ID = 1)
Begin
        Drop Table mybiao
End

Go

论坛徽章:
0
3 [报告]
发表于 2006-04-12 18:29 |只看该作者

临时表没有删除,下次就不能用了,可以简化一下,不用临时表。

Create procedure aaa
@a varchar(9)
as
Declare @SQL Varchar(200)
Select @SQL = \'Select 1 Where \' + @a
exec(@SQL)
if @@rowcount<>0
Begin
Drop Table mybiao
End

Go
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP