2016 - 2024

感恩一路有你

sql常用语句大全 如何在oracle存储过程中执行动态sql语句?

浏览量:2302 时间:2021-03-11 13:14:57 作者:admin

如何在oracle存储过程中执行动态sql语句?

时需要在oracle 存储过程中执行动态SQL 语句 ,例如表名是动态的,或字段是动态的,

或查询命令是动态的,可用下面的方法:

set serveroutput ondeclaren numbersql_stmt varchar2(50)

t varchar2(20)beginexecute immediate "alter session set nls_date_format=""YYYYMMDD"""

t := "t_" || sysdate

sql_stmt := "select count(*) from " || t

execute immediate sql_stmt into n

dbms_output.put_line("The number of rows of " || t || " is " || n)end

如果动态SQL 语句 很长很复杂,则可用包装.

CREATE OR REPLACE PACKAGE test_pkgISTYPE cur_typ IS REF CURSOR

PROCEDURE test_proc (v_table VARCHAR2,t_cur OUT cur_typ)END/

CREATE OR REPLACE PACKAGE BODY test_pkgISPROCEDURE test_proc (v_table VARCHAR2,t_cur OUT cur_typ)ISsqlstr VARCHAR2(2000)BEGINsqlstr := "SELECT * FROM "||v_table

OPEN t_cur FOR sqlstrENDEND/

在oracle 中批量导入,导出和删除表名以某些字符开头的表

spool c:a.sql

oracle存储过程循环执行SQL语句?

CREATE OR REPLACE PACKAGE BODY PKG_A_TESTPACKAGE IS

PROCEDURE PKG_A_TESTPROCEDURE(PRM_参数 IN VARCHAR2,

PRM_返回值 OUT NUMBER,

PRM_错误信息 OUT VARCHAR2) IS

TYPE CURSOR_TYPE IS REF CURSOR

CUR_SQL CURSOR_TYPE

TYPE TYP_REC_INFO IS RECORD(

COLUMN VARCHAR2(1000))

LREC_INFO TYP_REC_INFO

BEGIN

PRM_返回值 := 0

-- 循环获取查询SQL

FOR REC_SQL IN (SELECT 查询SQL FROM 存放SQL的表 WHERE 条件) LOOP

BEGIN

OPEN CUR_SQL FOR REC_SQL.查询SQL

LOOP

-- 获取查询的信息

FETCH CUR_SQL

INTO LREC_INFO --存放查询结果,这里只针对单列的查询结果

-- 如果没有取到退出

EXIT WHEN CUR_SQL%NOTFOUND

END LOOP

CLOSE CUR_SQL

END

END LOOP

EXCEPTION

WHEN OTHERS THEN

PRM_返回值 := -1

PRM_错误信息 := "执行PKG_A_TESTPROCEDURE出错"

END PKG_A_TESTPROCEDURE

END PKG_A_TESTPACKAGE

按照你的思路写的,具体需要根据你自己实际需求修改扩充一下

sql常用语句大全 sql基本语句大全 sql数据库怎么用

版权声明:本文内容由互联网用户自发贡献,本站不承担相关法律责任.如有侵权/违法内容,本站将立刻删除。