一篇关于SQL中的动态SQL

开发 前端
静态 SQL 语句一般用于嵌入式 SQL 应用中,在程序运行前,SQL 语句必须是确定的,例如 SQL 语句中涉及的列名和表名必须是存在的。静态 SQL 语句的编译是在应用程序运行前进行的,编译的结果会存储在数据库内部。

[[419849]]

在介绍动态SQL前我们先看看什么是静态SQL

静态SQL

静态 SQL 语句一般用于嵌入式 SQL 应用中,在程序运行前,SQL 语句必须是确定的,例如 SQL 语句中涉及的列名和表名必须是存在的。静态 SQL 语句的编译是在应用程序运行前进行的,编译的结果会存储在数据库内部。而后程序运行时,数据库将直接执行编译好的 SQL 语句,降低运行时的开销。

动态SQL

动态 SQL 语句是在应用程序运行时被编译和执行的,例如,使用 DB2 的交互式工具 CLP 访问数据库时,用户输入的 SQL 语句是不确定的,因此 SQL 语句只能被动态地编译。动态 SQL 的应用较多,常见的 CLI 和 JDBC 应用程序都使用动态 SQL。

动态SQL作用

  • 自动化管理任务。例如:对于数据库实例中的每个数据库,查询其元数据,为其执行BACKUP DATABASE语句。
  • 改善特定任务的性能。例如,构造参数化的特定查询,以重用以前缓存过的执行计划。
  • 对实际数据进行查询的基础上,构造代码元素。例如,当事先不知道再PIVOT运算符的IN子句中应该出现哪些元素时,动态构造PIVOT查询。

动态SQL执行方法

使用EXEC(EXECUTE的缩写)命令和使用SP_EXECUTERSQL。

EXEC命令执行

语法

  • EXECUTE (SQL语句)

注:EXECUTE 命令有两个用途,一个是用来执行存储过程,另一个是执行动态SQL

不带参数示例

在变量@SQL中保存了一个字符串,该字符串中包含一条查询语句,再用EXEC调用保存在变量中的批处理代码,我们可以这样写SQL:

  1. EXEC ('SELECT * FROM Customers'

结果如下:

与我们直接执行SELECT * FROM Customers一样。

带参数示例

还是上面的示例,我们换一种写法

  1. DECLARE @SQL AS VARCHAR(100); 
  2. DECLARE @Column AS VARCHAR(20); 
  3. SET @Column = '姓名' 
  4. SET @SQL = 'SELECT ' + @Column + ' FROM Customers'
  5. EXEC (@SQL) 

结果如下:

SP_EXECUTERSQL执行

语法

EXEC SP_EXECUTERSQL 参数1,参数2,参数3

注意:SP_EXECUTERSQL是继EXEC后另一种执行动态SQL的方法。使用这个存储过程更加安全和灵活,因为它支持输入和输出参数。注意的是,与EXEC不同的是,SP_EXECUTERSQL只支持使用Unicode字符串作为其输入的批处理代码。

示例

构造了一个对Customers表进行查询的批处理代码,在其查询过滤条件中使用一个输入参数@CusID

  1. DECLARE @SQL AS NVARCHAR(100); 
  2. SET @SQL=N'SELECT * FROM Customers 
  3. WHERE 客户ID=@CusID;'; 
  4.  
  5. EXEC SP_EXECUTESQL 
  6.     @STMT=@SQL, 
  7.     @PARMS=N'@CusID AS INT'
  8.     @CusID=1; 

结果如下:

代码中将输入参数取值指定为1,但即使采用不同的值在运行这段代码,代码字符串仍然保存相同。这样就可以增加重用以前缓存过的执行计划的机会。

总结 

动态SQL在日常工作中可能接触的比较少,但是其功能是非常强大的,可以直接嵌套在代码里进行操作数据,但是也很容易出错,特别是在进行命令拼接时候要非常仔细。这里只是给大家简单介绍一下其使用方法,需要深入使用还需要多多研究。

 

责任编辑:武晓燕 来源: SQL数据库开发
相关推荐

2021-08-12 07:49:24

SQL递归用法

2023-02-28 23:04:15

2021-09-15 19:05:16

数据开源项目

2017-12-17 20:17:23

NoSQLSQL数据

2021-10-11 11:08:33

HDFS快照系统

2018-08-13 09:20:21

NoSQLSQL数据

2011-06-21 09:14:01

Oracle查询

2020-03-09 17:28:51

NoSQLMongoDB数据库

2010-11-12 13:08:36

动态sql语句

2010-08-05 09:07:24

2022-03-02 11:37:57

参数性能调优

2021-05-14 16:34:12

Semaphore原理

2022-05-08 19:58:10

JSONPJavaScript

2021-09-05 07:55:36

Lsm核心实现

2021-09-06 06:31:40

理解动态规划

2021-07-12 10:36:36

Blazor组件入门

2022-11-08 10:52:25

Flowable节点表单

2022-04-02 09:38:00

CSS3flex布局方式

2021-04-18 18:03:06

工作树远程版本

2021-09-08 09:22:34

SentryCLIOS
点赞
收藏

51CTO技术栈公众号