在介绍动态SQL前我们先看看什么是篇关静态SQL
静态 SQL 语句一般用于嵌入式 SQL 应用中,在程序运行前,动态SQL 语句必须是篇关确定的,例如 SQL 语句中涉及的动态列名和表名必须是存在的。静态 SQL 语句的篇关编译是在应用程序运行前进行的,编译的动态结果会存储在数据库内部。而后程序运行时,篇关数据库将直接执行编译好的动态 SQL 语句,降低运行时的篇关开销。
动态 SQL 语句是动态在应用程序运行时被编译和执行的,例如,篇关使用 DB2 的动态交互式工具 CLP 访问数据库时,用户输入的篇关 SQL 语句是不确定的,因此 SQL 语句只能被动态地编译。动态动态 SQL 的篇关应用较多,站群服务器常见的 CLI 和 JDBC 应用程序都使用动态 SQL。
使用EXEC(EXECUTE的缩写)命令和使用SP_EXECUTERSQL。
EXEC命令执行
语法
EXECUTE (SQL语句)注:EXECUTE 命令有两个用途,一个是用来执行存储过程,另一个是执行动态SQL
不带参数示例
在变量@SQL中保存了一个字符串,该字符串中包含一条查询语句,再用EXEC调用保存在变量中的批处理代码,我们可以这样写SQL:
EXEC (SELECT * FROM Customers)结果如下:
与我们直接执行SELECT * FROM Customers一样。
带参数示例
还是服务器托管上面的示例,我们换一种写法
DECLARE @SQL AS VARCHAR(100); DECLARE @Column AS VARCHAR(20); SET @Column = 姓名 SET @SQL = SELECT + @Column + FROM Customers; EXEC (@SQL)结果如下:
SP_EXECUTERSQL执行
语法
EXEC SP_EXECUTERSQL 参数1,参数2,参数3
注意:SP_EXECUTERSQL是继EXEC后另一种执行动态SQL的方法。使用这个存储过程更加安全和灵活,因为它支持输入和输出参数。注意的是,与EXEC不同的是,SP_EXECUTERSQL只支持使用Unicode字符串作为其输入的批处理代码。
示例
构造了一个对Customers表进行查询的批处理代码,在其查询过滤条件中使用一个输入参数@CusID
DECLARE @SQL AS NVARCHAR(100); SET @SQL=NSELECT * FROM Customers WHERE 客户ID=@CusID;; EXEC SP_EXECUTESQL @STMT=@SQL, @PARMS=N@CusID AS INT, @CusID=1;结果如下:
代码中将输入参数取值指定为1,但即使采用不同的值在运行这段代码,代码字符串仍然保存相同。这样就可以增加重用以前缓存过的执行计划的机会。
动态SQL在日常工作中可能接触的比较少,但是其功能是非常强大的,可以直接嵌套在代码里进行操作数据,但是也很容易出错,特别是亿华云在进行命令拼接时候要非常仔细。这里只是给大家简单介绍一下其使用方法,需要深入使用还需要多多研究。