merge into在oracle10g和oracle 11g中的使用差别一
oracle10g上的代码
MERGE INTO TCGGYSGHCP CP
USING (SELECT *
FROM (SELECT QD.LIFNR,
QD.MATNR,
MAX(MX.DATAB) DATAB,
MAX(MX.DATBI) DATBI,
QD.LOEKZ,
QD.SESSIONID,
MAX(QD.CREATEDATE) CREATEDATE,
QD.STATUS
FROM T_SAP2SCF_GHCP QD
LEFT JOIN A018 MX
ON MX.SESSIONID = QD.SESSIONID
AND MX.MATNR = QD.MATNR
AND MX.LIFNR = QD.LIFNR
WHERE QD.SESSIONID = P_SESSIONID
GROUP BY QD.LIFNR,
QD.MATNR,
QD.LOEKZ,
QD.SESSIONID,
QD.STATUS)) T
ON (CP.WLBM = T.MATNR AND CP.GYSBM = T.LIFNR)
WHEN MATCHED THEN
UPDATE
SET CP.ISDELETE = T.LOEKZ,
CP.TCCYTZSRQ = T.DATAB,
CP.TCQXTZSRQ = T.DATBI,
CP.GYSMC =
(SELECT XX.GYSMC FROM TCGGYSXX XX WHERE XX.GYSBM = T.LIFNR),
CP.WLMC =
(SELECT WL.WLMC FROM TPRIWLZSJ WL WHERE WL.WLBM = MATNR)
WHEN NOT MATCHED THEN
INSERT
(ZZBM,
ZZXLH,
WLBM,
WLMC,
ISDELETE,
TCCYTZSRQ,
TCQXTZSRQ,
GYSBM,
GYSMC)
VALUES
('5920',
'1003',
MATNR,
(SELECT WL.WLMC FROM TPRIWLZSJ WL WHERE WL.WLBM = MATNR),
LOEKZ,
DATAB,
DATBI,
LIFNR,
(SELECT XX.GYSMC FROM TCGGYSXX XX WHERE XX.GYSBM = T.LIFNR));
这段代码在oracle11g中编译报错
经过跟踪发现 子操作中的子查询去掉就可以,在此可以把子操作中的子查询数据放入到主查询中,子操作直接引用即可。
merge into在oracle10g和oracle 11g中的使用差别一的更多相关文章
- Oracle 11g中修改默认密码过期天数和锁定次数
Oracle 11g中修改默认密码过期天数和锁定次数 密码过期的原因一般有两种可能: 一.由于Oracle中默认在default概要文件中设置了"PASSWORD_LIFE_TIME=180 ...
- 盘点 Oracle 11g 中新特性带来的10大性能影响
Oracle的任何一个新版本,总是会带来大量引人瞩目的新特性,但是往往在这些新特性引入之初,首先引起的是一些麻烦,因为对于新技术的不了解.因为对于旧环境的不适应,从Oracle产品到技术服务运维,总是 ...
- Oracle 11g中的snapshot standby特性
在Oracle 11g中,data guard最吸引人的,除了active data guard的实时查询特性(即可以以只读方式打开物理standby数据库的同时MRP进程能继续做recover),快 ...
- oracle 11g中的自动维护任务管理
因为人员紧缺,最近又忙着去搞性能优化的事情,有时候真的是不想再搞这个事情,只是没办法,我当前的绩效几乎取决于这个项目的最终成绩,所以不管是人的事还是事的事,都得去让他顺利推进. 前段时间发生还有几台服 ...
- oracle 11g 中 (oracle 10g) crsctl 的 替换命令
oracle 11g 中 (oracle 10g) crsctl 的 替换命令 Deprecated Command Replacement Commands crs_stat ---集群状态 ...
- Oracle 11g 中SQL性能优化新特性之SQL性能分析器(SQLPA)
Oracle11g中,真实应用测试选项(the Real Application Testing Option)提供了一个有用的特点,叫SQL性能分析器(SQL Performance Analyze ...
- Oracle 11g中修改被锁定的用户:scott
在安装完Oracle10g和创建完oracle数据库之后,想用数据库自带的用户scott登录,看看连接是否成功. 在cmd命令中,用“sqlplus scott/ tiger”登录时,老是提示如下信息 ...
- Oracle 11g 中恢复管理器RMAN介绍
这是我平时摘录的笔记,从管理艺术那本书上摘录出来的,放到这里 RMAN 可在数据库服务器的帮助下从数据库内备份数据文件,可构造数据文件映像副本.控制文件和控制文件映像.对当日志 SPFILE 和RMA ...
- Oracle 11g中查询CPU占有率高的SQL
oracle版本:oracle11g 背景:今天在Linux中的oracle服务上,运用top命令发现许多进程的CPU占有率是100%. 操作步骤: 以进程PID:7851为例 执行以下语句: 方法一 ...
随机推荐
- babel6 的 export default bug
把export default 变成 module.exports 就行了
- Hibernate设置自增
hibernate设置自增,在映射生成的实体类中需要实现Serializable接口 public class GWgDyEntity implements Serializable { //在主键上 ...
- jquery autocomplete
<!DOCTYPE html> <html> <head> <link rel="stylesheet" href="http: ...
- C# 利用反射
.NET基础篇——反射的奥妙 C#获取实体类属性名和值 | 遍历类对象 c#通过反射获取类上的自定义特性 C#利用反射+特性实现简单的实体映射数据库操作类
- php日常日志写入格式记录
从数据库取出数据数组格式保存 file_put_contents('/tmp/bak_trusted_list'.date('H').'.php', '<?php return '.var_ex ...
- ThinkPHP之登录验证
验证方面写的不是很完整,正在完善当中 <?php /** * Created by dreamcms. * User: Administrator * Date: 2016/9/5 * Time ...
- Bootstrap相关总结
1.工具提示 Tooltips js调用显示 $('#example').tooltip( { title:'这个是一个提示', }); $('#example').tooltip('show');
- inline、block、inline-block的区别
http://www.cnblogs.com/KeithWang/p/3139517.html
- .NET蓝牙开源库:32feet.NET
在用C#调用蓝牙编程一文中我留个小悬念就是:InTheHand.Net.Personal.dll是怎么来的?这篇文章来解答这个问题,InTheHand.Net.Personal.dll就是来源于今天要 ...
- 3.UIViewController详解
一. UIViewController,视图控制器,它是UIKit中非常重要的组成部分.它由控制器+View两部分组成. 控制器功能: ->实现代码逻辑,决定它自带的View的界面显示. -& ...