动态sql mysql_动态SQL语句_MySQL「建议收藏」

动态sql mysql_动态SQL语句_MySQL「建议收藏」1:普通SQL语句可以用Exec执行eg:Select*fromtableNameExec(‘select*fromtableName’)sp_executesqlN’select*fromtableName’–请注意字符串前一定要加N2:字段名,表名,数据库名之类作为变量时,必须用动态SQLeg:declare@fnamevarchar(20)set@…

大家好,又见面了,我是你们的朋友全栈君。

1:普通SQL语句可以用Exec执行

eg: Select * from tableName

Exec(‘select * from tableName’)

sp_executesql N’select * from tableName’ — 请注意字符串前一定要加N

2:字段名,表名,数据库名之类作为变量时,必须用动态SQL

eg:

declare @fname varchar(20)

set @fname = ‘[name]’

Select @fname from sysobjects — 错误

Exec(‘select ‘ + @fname + ‘ from sysobjects’) — 请注意 加号前后的 单引号的边上要加空格

exec sp_executesql N’ select ‘ + @fname + ‘ from sysobjects’

当然将字符串改成变量的形式也可

declare @s varchar(1000)

set @s = ‘select ‘ + @fname + ‘ from sysobjects’

Exec(@s) — 成功

exec sp_executesql @s — 此句会报错

declare @s Nvarchar(1000) — 注意此处改为nvarchar(1000)

set @s = ‘select ‘ + @fname + ‘ from sysobjects’

Exec(@s) — 成功

exec sp_executesql @s — 此句正确,

3: 输出参数

eg:

declare @num,

@sqls

set @sqls=’select count(*) from ‘ + @servername + ‘.a.dbo.b’

exec(@sqls)

我如何能将exec执行的结果存入变量@num中

declare @num int,

@sqls nvarchar(4000)

set @sqls=’select @a=count(*) from ‘+@servername+’.a.dbo.b’

exec sp_executesql @sqls,N’@a int output’,@num output

select @num

f68f2add0b68e4f9810432fce46917b7.png

相关标签:用 动态

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/152519.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Java中Scanner用法总结

    Java中Scanner用法总结最近在做OJ类问题的时候,经常由于Scanner的使用造成一些细节问题导致程序不通过(最惨的就是网易笔试,由于sc死循环了也没发现,导致AC代码也不能通过。。。),因此对Scanner进行了一些总结整理。Scanner类简介Java5添加了java.util.Scanner类,这是一个用于扫描输入文本的新的实用程序。它是以前的StringTokenizer和Matcher类之间的某种结合。由于任何

    2022年7月20日
    11
  • 2010款汉兰达参数配置_windows安装程序兼容性报告

    2010款汉兰达参数配置_windows安装程序兼容性报告
    关于配置TFS2010的总结:
    TFS2010是我第一次配置,这个东西配置有点麻烦,我还从来没有用过,听经理说,他好像类似于一个大管家,将项目的的需求管理,跟踪,版本管理,测试管理等一系列功能综合在一起,免去了做一个项目要选择许多管理工具的繁琐问题,经理说要不惜一切代价搞定这个东西,在安装的过程中走了很多弯路。
     
    我是参考一篇关于TFS配置的文章配置的,文章介绍的很详细,有插图(我会将它分享给大家),但是我在实际安装的时候还是除了很多问题
    开始我很发愁

    2022年9月14日
    0
  • python监控网页变化教程_Python实时监控网站浏览记录实现过程详解

    python监控网页变化教程_Python实时监控网站浏览记录实现过程详解需求:(1)获取你对象chrome前一天的浏览记录中的所有网址(url)和访问时间,并存在一个txt文件中(2)将这个txt文件发送给指定的邮箱地址(你的邮箱)(3)建立例行任务,每天定时自动完成这些操作,你就可以通过邮件查看你对象每天看啥了准备macOSSierraPython3.6Chrome发送邮件的qq邮箱地址qq邮箱授权码SMTP服务器地址:smtp.qq.com接受邮件的邮箱地…

    2022年7月16日
    16
  • servlet的运行原理_高铁怎么运行的原理

    servlet的运行原理_高铁怎么运行的原理Servlet在容器中的执行过程1.浏览器向服务器发出GET请求2.服务器上的Tomcat接收到该url,根据该url判断为Servlet请求,此时Tomcat将产生两个对象:请求对象(HttpServletRequest)和响应对象(HttpServletResponce)3.Tomcat根据url找到目标Servlet,且创建一个线程4.Tomcat将刚才创建的请求对象和响应对象传递…

    2022年10月1日
    0
  • openCV基本绘图函数—-画圆函数cvCircle

    openCV基本绘图函数—-画圆函数cvCircle#include #include#include usingnamespacecv; intmain(intargc,char**argv){    IplImage*img=cvLoadImage(“D:\\123\\2.jpg”,1);    cvCircle(img,cvPoint(120,120),90,c

    2022年7月24日
    8
  • datagrip 2022.01.13 激活码【2022最新】2022.03.10

    (datagrip 2022.01.13 激活码)2021最新分享一个能用的的激活码出来,希望能帮到需要激活的朋友。目前这个是能用的,但是用的人多了之后也会失效,会不定时更新的,大家持续关注此网站~https://javaforall.net/100143.htmlIntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,上面是详细链接哦~1M…

    2022年4月2日
    541

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号