博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Oracle:WITH AS () Merge ?
阅读量:5320 次
发布时间:2019-06-14

本文共 729 字,大约阅读时间需要 2 分钟。

WITH AS 语法在SQL SERVER 和ORACLE数据库上均支持,主要用于子查询。语法如下:

WITH expression_name [ ( column_name [,...n] ) ]AS( CTE_query_definition )--只有在查询定义中为所有结果列都提供了不同的名称时,列名称列表才是可选的。--运行 CTE 的语句为:SELECT 
FROM expression_name;

但其语句在两个数据库的应用却有所不同,比如在SQL SERVER 数据库上,这种语法叫做CTE,CTE后面必须直接跟使用CTE的SQL语句(如select、insert、update、merge等),否则,CTE将失效。

但是对于Oracle数据库而言,却有一个限制比较头疼,就是WITH AS后面需要紧跟SELECT语句。那如果需要执行MERGE该如何是好呢?

简单,将MERGE 语句提前即可。

举例说明:

MERGE INTO #TEMP1 AUSING (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语句!

转载于:https://www.cnblogs.com/sheng-jie/p/8795207.html

你可能感兴趣的文章
Ubuntu 12.04 Firefox/Chromium缺少Flash Player问题
查看>>
在线文件管理器elFinder支持中文
查看>>
String比较
查看>>
Django之Models
查看>>
动态添加SqlParameter
查看>>
SQLServer:探讨EXEC与sp_executesql的区别详解
查看>>
Spring缓存注解@Cache使用
查看>>
CSS 透明度级别 及 背景透明
查看>>
Linux定时任务(crond)
查看>>
apache编译安装php后需要注意以下配置
查看>>
20)升级登录标志
查看>>
机器学习之GMM-EM
查看>>
Linux 的 date 日期的使用
查看>>
PHP zip压缩文件及解压
查看>>
为MS SQL 2005加入一个用户admin
查看>>
HTML5 LocalStorage 本地存储
查看>>
SOAP web service用AFNetWorking实现请求
查看>>
jQuery Easy UI Resizable(调整大小)组件
查看>>
android AlarmManager采用
查看>>
Sail
查看>>