动态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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • docker 上传本地镜像_不同docker仓库镜像同步

    docker 上传本地镜像_不同docker仓库镜像同步前言之前通过docker搭建过jenkins+python3环境,如果想要在不同的机器上搭建一样的环境,就可以将之前搭建的镜像上传到镜像仓库,这样方便在不同的机器上快速搭建同一套环境。如果公开的话

    2022年7月31日
    6
  • oracle定义游标例子_sqlserver游标实例

    oracle定义游标例子_sqlserver游标实例大佬教程收集整理的这篇文章主要介绍了Oracle游标的使用实例详解,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。什么是游标?①从表中检索出结果集,从中每次指向一条记录进行交互的机制。②关系数据库中的操作是在完整的行集合上执行的。由SELECT语句返回的行集合包括满足该语句的WHERE子句所列条件的所有行。由该语句返回完整的行集合叫做结果集。应用程序,尤其是互动和在线应用程序…

    2025年6月30日
    3
  • 程序员计算器在线计算_安卓程序员计算器

    程序员计算器在线计算_安卓程序员计算器在线标准程序员计算器在线标准程序员计算器本工具支持在线提供免费计算器工具,包括标准、科学及程序员计算工具https://tooltt.com/calc/

    2022年8月2日
    5
  • sbc音频编解码是什么_人工智能fpga算法工程师

    sbc音频编解码是什么_人工智能fpga算法工程师转自:https://blog.csdn.net/wzz4420381/article/details/48676921原作者:wzz44203811.SBC算法简介SBC是subbandcode的缩写,也可称为子带编码 在A2DP协议中,SBC算法是默认支持的 蓝牙SBC算法是一种以中等比特率传递高质量音频数据的低计算复杂度的音频编码算法1.1算法基本框图SB…

    2025年10月29日
    2
  • sql is not null 优化(oracle语句索引优化)

    oracle优化:ISNULL的优化优化方法:通过nvl(字段i,j),将字段i中为空的数据转化为j,从而将条件iisnull转化为j=nvl(i,j);转化isnull在所用oracle版本提升明显,注意:使用时必须确保字段i的数据不包含j!函数介绍:nvl(a,b,c,…)当a为空时取b,当b为空取c,以此类推.优化示例select*fromtab_i…

    2022年4月17日
    577
  • java容器类—概述

    java容器类—概述

    2022年2月6日
    74

发表回复

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

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