Oracle——无法在查询中执行 DML 操作
今天在调用Oracle Function遇到一个异常
这是我的函数(为了再现随手写的)
create or replace function test_f(id varchar2) return varchar2 is
Result varchar2(100);
begin
insert into sfcs_temp_17109
(sn)values(id);
commit;
return result;
end test_f;
解决方法:增加PRAGMA AUTONOMOUS_TRANSACTION(自治事务介绍)
create or replace function test_f(id varchar2) return varchar2 is
Result varchar2(100);
PRAGMA AUTONOMOUS_TRANSACTION;
begin
insert into sfcs_temp_17109
(sn)values(id);
commit;
return result;
end test_f;
然后又遇到第二个问题
function如下:
create or replace function test_f(id varchar2) return varchar2 is
Result varchar2(100);
PRAGMA AUTONOMOUS_TRANSACTION;
MSD_PN VARCHAR2(50);
begin
BEGIN
select didbar into MSD_PN from t_did where diddid = ID;
IF MSD_PN IS NOT NULL THEN
RESULT := 'ERROR:' || ID || '在系統中不存在!';
RETURN RESULT;
END IF;
END;
insert into sfcs_temp_17109 (sn) values (id);
commit;
return result;
end;
Return Result commit或者Rollback
create or replace function test_f(id varchar2) return varchar2 is
Result varchar2(100);
PRAGMA AUTONOMOUS_TRANSACTION;
MSD_PN VARCHAR2(50);
begin
BEGIN
select didbar into MSD_PN from t_did where diddid = ID;
IF MSD_PN IS NOT NULL THEN
RESULT := 'ERROR:' || ID || '在系統中不存在!';
commit;
RETURN RESULT;
END IF;
END;
insert into sfcs_temp_17109 (sn) values (id);
commit;
return result;
end;
增加commit后即可正常使用。
Oracle——无法在查询中执行 DML 操作的更多相关文章
- Oracle中 “ORA-14551: 无法在查询中执行 DML 操作” 如何解决
在编写一个数据库函数时,方法实现需要查询后进行修改,出现ora-14551的错误 create or replace function fun_DxcBillSn(tabType integer,ta ...
- PL/SQL“ ORA-14551: 无法在查询中执行 DML 操作”解决
环境 Oracle 11.2.0 + SQL Plus 问题 根据以下要求编写函数:将scott.emp表中工资低于平均工资的职工工资加上200,并返回修改了工资的总人数.PL/SQL中有更新的操作, ...
- ORA-14551: 无法在查询中执行 DML 操作
编写了一个oracle函数,函数体内实现一系列数据库的逻辑处理,涉及到数据的增删等操作,返回NCLOB类型. 然后通过查询方式调用函数: SELECT PKG.MY_FUN('A') FROM DUA ...
- 利用sqoop对mysql执行DML操作
业务背景 利用Sqoop对MySQL进行查询.添加.删除等操作. 业务实现 select操作: sqoop eval \ --connect jdbc:mysql://127.0.0.1:3306/m ...
- CountDownLatch,一个同步辅助类,在完成一组正在其他线程中执行的操作之前,它允许一个或多个线程一直等待。
CountDownLatch,一个同步辅助类,在完成一组正在其他线程中执行的操作之前,它允许一个或多个线程一直等待. 主要方法 public CountDownLatch(int count); pu ...
- Oracle DBLINK 抽数以及DDL、DML操作
DB : 11.2.0.3.0 原库实例orcl:SQL> select instance_name from v$instance; INSTANCE_NAME--------------- ...
- mysql、sql server、oracle数据库分页查询及分析(操作手册)
1.mysql分页查询 方式1: select * from table order by id limit m, n; 该语句的意思为,查询m+n条记录,去掉前m条,返回后n条记录.无疑该查询能够实 ...
- Oracle入门之对表内容的dml操作
oracle表的管理--添加数据 使用insert语句向表中插入数据 插入数据基本语法: insert into table[(column [,column...])] values(value [ ...
- C# Winform中执行post操作并获取返回的XML类型的数据
/// <summary> /// 返回指定日期的订单数据 /// </summary> /// <param name="StartDate"> ...
随机推荐
- MintUI引入vue项目以及引入iconfont图标
官网地址:http://mint-ui.github.io/#!/zh-cn 中文文档:http://mint-ui.github.io/docs/#/zh-cn2 示例展示:http://eleme ...
- Sql注入基本思路
Sql注入基本思路 利用mysql自己动手 登录 使用show databases;查看数据库,sql注入主要用到的是information_schema这个库(mysql中大小写不敏感) infor ...
- pdf 翻译
某某狗 https://www.fanyigou.com/tslg/share/4DO875ON.htm
- 软件工程--团队项目选择与NABCD
目录 Part1:项目说明 项目基础 我们的目标 Part2:项目NABCD Need Approach Benefit Competitors Delivery & Data Deliver ...
- Thinking In SE
各种编程范式的区别 并发模型 并行架构: 位级(bit-level)并行 指令级(instruction-level)并行 数据级(data)并行 数据级并行 任务级(task-level)并行 -- ...
- Phpoffice 已经弃用
Package phpoffice/phpexcel is abandoned, you should avoid using it. Use phpoffice/phpspreadsheet i ...
- JVM探究之 —— HotSpot虚拟机对象探秘
本节以常用的虚拟机HotSpot和常用的内存区域Java堆为例,深入探讨HotSpot虚拟机在Java堆中对象分配.布局和访问的全过程. 1. 对象的创建 Java是一门面向对象的编程语言.在语言层面 ...
- PostgreSQL中的表连接操作
- 泡泡一分钟:GEN-SLAM - Generative Modeling for Monocular Simultaneous Localization and Mapping
张宁 GEN-SLAM - Generative Modeling for Monocular Simultaneous Localization and Mapping GEN-SLAM - 单 ...
- mysql8忘记秘密-重置密码步骤
mysql8修改密码的方式有些许不同 1.配置无密码登录 修改/etc/my.cnf文件,在mysqld模块下添加 skip-grant-tables 2.重启mysql 3.mysql -uroot ...