plsql开发中动态sql的使用教程(不使用dbms_sql包)

一般的PL/SQL程序设计中,在DML和事务控制的语句中可以直接使用SQL,但是对于新建存储过程,其中涉及传参要被应用为列名时,不能在PL/SQL中直接使用,一会儿下面举例介绍,那么要想实现设计的功能,可以通过使用动态SQL来实现。

首先我们应该了解什么是动态SQL,在Oracle数据库开发PL/SQL块中我们使用的SQL分为:静态SQL语句和动态SQL语句。所谓静态SQL指在PL/SQL块中使用的SQL语句在编译时是明确的,执行的是确定对象。而动态SQL是指在PL/SQL块编译时SQL语句是不确定的,如根据用户输入的参数的不同而执行不同的操作。编译程序对动态语句部分不进行处理,只是在程序运行时动态地创建语句、对语句进行语法分析并执行该语句。

Oracle中动态SQL可以通过本地动态SQL来执行,也可以通过DBMS_SQL包来执行。本篇文章我们只介绍本地动态执行sql:

oracle 12版本以上适用:

动态sql

sql 复制代码
drop package su1;

create or replace package su as

​	function get_id() return varchar2;

end su;

/

create or replace package body su1 as

​	function get_id() return varchar2

​	as

​	str_sql varchar2(200);

​	b varchar2(200);

​	begin

​		str_sql := 'select * from b1';

​		execute immediate str_sql into b;

​		return b;

​	end;

end su1;

/

select su1.get_id() from dual;

create or replace package su as

​	function get_id(tabname in varchar2) return varchar2;

end su;

/

create or replace package body su1 as

​	function get_id(tabname in varchar2) return varchar2

​	as

​	str_sql varchar2(200);

​	b varchar2(200);

​	begin

​		str_sql := 'select * from '||tabname||'';

​		execute immediate str_sql into b;  --注意这里仅有一行数据返回

​		return b;

​	end;

end su1;

/

select su1.get_id('b1') from dual;
相关推荐
Nturmoils14 小时前
订单列表慢查询,先看 WHERE、ORDER BY 和 LIMIT
数据库
渣波18 小时前
拒绝 SQL 焦虑!手把手带你用 NestJS + Prisma + DTO 写出“防弹”级后端代码
javascript·数据库·后端
倔强的石头_2 天前
KingbaseES 新版MySQL 兼容版体验:旧版迁移 + 功能实测
数据库
zzzzzz3103 天前
9K Star 炸裂开源!这个 C 语言写的代码知识图谱,把 Linux 内核索引压缩到了 3 分钟
linux·服务器·sql
倔强的石头_5 天前
《Kingbase护城河》——数据库存储空间全景探测与精细化瘦身实战
数据库
云技纵横5 天前
唯一索引 INSERT 死锁实战:5 秒复现交叉插入的 S 锁循环等待
sql·mysql
冬奇Lab5 天前
每日一个开源项目(第134篇):Zvec - 阿里开源的嵌入式向量数据库,向量搜索界的 SQLite
数据库·人工智能·llm
ClouGence6 天前
Oracle CDC 架构优化:从主库直连到 DataGuard 备库同步
数据库·后端·oracle
无响应de神6 天前
三、用户与权限管理
数据库·mysql
麦聪聊数据6 天前
数据服务化时代:企业数据能力输出的核心路径
数据库