VastbaseG100

基于openGauss内核开发的企业级关系型数据库。

Menu

执行动态非查询语句

功能描述

动态非查询就是在程序运行的时候来进行非查询操作。

语法格式

noselect::=

using_clause子句的语法参见下图。

using_clause::=

参数说明

USING IN bind_argument

用于指定存放传递给动态SQL值的变量,在dynamic_noselect_string中存在占位符时使用,即动态SQL语句执行时,bind_argument将替换相对应的占位符。

bind_argument只能是值、变量或表达式,不能是表名、列名、数据类型等数据库对象。如果存储过程需要通过声明参数传递数据库对象来构造动态SQL语句(常见于执行DDL语句时),建议采用连接运算符“||”拼接dynamic_select_clause。另外,动态语句允许出现重复的占位符,相同占位符只能与唯一 一个bind_argument按位置一一对应。

示例

1、创建测试表。

CREATE TABLE sections_t1 
( 
  section    NUMBER(4) , 
  section_name  VARCHAR2(30), 
  manager_id   NUMBER(6), 
  place_id    NUMBER(4)  
); 

2、声明变量并执行动态非查询语句。

DECLARE  
  section    NUMBER(4) := 280;  
  section_name  VARCHAR2(30) := 'Info support';  
  manager_id   NUMBER(6) := 103; 
  place_id    NUMBER(4) := 1400; 
  new_colname  VARCHAR2(10) := 'sec_name'; 
BEGIN
--执行查询
EXECUTE IMMEDIATE 'insert into sections_t1 values(:1, :2, :3, :4)'  
USING section, section_name, manager_id,place_id;  
--执行查询(重复占位符)
EXECUTE IMMEDIATE 'insert into sections_t1 values(:1, :2, :3, :1)'  
USING section, section_name, manager_id, section;
--执行ALTER语句(建议采用“||”拼接数据库对象构造DDL语句) 
EXECUTE IMMEDIATE 'alter table sections_t1 rename section_name to ' || new_colname; 
END;  
/ 

3、查询数据。

SELECT * FROM sections_t1; 

返回结果为:

 section |   sec_name   | manager_id | place_id
---------+--------------+------------+----------
     280 | Info support |        103 |     1400
     280 | Info support |        103 |      280
(2 rows)

4、删除表 。

DROP TABLE sections_t1;