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;
相关推荐
货拉拉技术4 分钟前
货拉拉RAG优化实践:从原始数据到高质量知识库
数据库·算法
张较瘦_13 分钟前
数据库|数据库设计范式:用“宠物管理系统“讲透1nf 2nf 3nf的关键逻辑
数据库·开发
源来猿往14 分钟前
并发之锁介绍
数据库
路边草随风17 分钟前
starrocks compaction 进度问题定位
大数据·sql
曹牧27 分钟前
Oracle:“列不能外部关联到子查询”
数据库·sql
档案宝档案管理42 分钟前
核心功能揭秘——档案管理系统如何破解档案管理难题?
大数据·数据库·安全·档案·档案管理
Databend1 小时前
如何打造AI时代的数据基石 | Databend Meetup 上海站回顾
数据库
wudl55661 小时前
向量数据库--FAISS
数据库·faiss
冲的运维日常1 小时前
Redis:查看RDB文件内容
数据库·redis·缓存
艾体宝IT1 小时前
艾体宝干货 | Redis Java 开发系列#1 从零开始的环境搭建与实践指南
数据库