Oracle:WITH AS () Merge ?
程序员文章站
2024-03-25 10:53:34
...
WITH AS 语法在SQL SERVER 和ORACLE数据库上均支持,主要用于子查询。语法如下:
WITH expression_name [ ( column_name [,...n] ) ]
AS
( CTE_query_definition )
--只有在查询定义中为所有结果列都提供了不同的名称时,列名称列表才是可选的。
--运行 CTE 的语句为:
SELECT <column_list> FROM expression_name;
但其语句在两个数据库的应用却有所不同,比如在SQL SERVER 数据库上,这种语法叫做CTE,CTE后面必须直接跟使用CTE的SQL语句(如select、insert、update、merge等),否则,CTE将失效。
但是对于Oracle数据库而言,却有一个限制比较头疼,就是WITH AS后面需要紧跟SELECT语句。那如果需要执行MERGE该如何是好呢?
简单,将MERGE 语句提前即可。
举例说明:
MERGE INTO #TEMP1 A
USING (
WITH SUMORDER AS
(SELECT PRODUCTID, SUM(AMOUNT) TOTAL
FROM ORDER GROUP BY PRODUCTID)
SELECT * FROM SUMORDER
) B ON (A.PRODUCTID = B.PRODUCTID)
WHEN MATCHED THEN UPDATE SET A.TOTAL = B.TOTAL;
同理,适用于其他SQL语句!
推荐阅读
-
ORACLE WITH AS的使用
-
Oracle:WITH AS () Merge ?
-
ORA-01033 ORACLE正在初始化或关闭
-
ORACLE中VARCHAR2类型的字段长度是按照byte来定义的-一个容易被忽略的问题 博客分类: 数据库 Oracle字符字节varchar2char
-
几个常用的存储过程,适用于ORACLE 博客分类: 数据库
-
几个常用的存储过程,适用于ORACLE 博客分类: 数据库
-
Oracle常见死锁发生的原因以及解决办法 博客分类: oracle备忘录 oracle死锁外键索引
-
Python使用cx_Oracle连接Oracle数据库
-
使用cx_Oracle 创建会话池sessionpool 及使用
-
cx_Oracle