GBase 8s V8.8 SQL 指南:教程-6.5(1)

6.5 集合运算
标准集合运算联合、相交和差异允许您处理数据库信息。这三种运算允许您使用 SELECT 
语句在执行更新、插入和删除之后检查数据库的完整性。例如:当数据库传送值历史记录
表,并且想要从原始表中删除数据之前验证历史记录表中的数据是否正确时,它们就非常
有用。
6.5.1 联合
联合运算使用 UNION 运算符将两个查询组合成单个复合查询。可以在两个或多个
SELECT 语句之间使用 UNION 运算符来产生一个临时表,它包含存在于任何一个原始表
或所有原始表中的行。还可以在视图的定义中使用 UNION 运算符。
不能在下列上下文的子查询内使用 UNION 运算符
• 在 SELECT 语句的 Projection 子句中
• 在 SELECT 、INSERT 、DELETE 或 UPDATE 语句的 WHERE 子句中
然而,UNION 运算符在 SELECT 语句的 FROM 子句中的子查询中是有效的,如下所示:
SELECT * FROM (SELECT col1 FROM tab1 WHERE col1 = 100) AS vtab1(c1),
 (SELECT col1 FROM tab2 WHERE col1 = 10 
 UNION ALL 
 SELECT col1 FROM tab1 WHERE col1 < 50 ) AS vtab2(vc1);
GBase 8s 不支持对 ROW 类型进行排序。由于 UNION 操作需要排序以除去重复值,所以
当联合运算中的任一查询包括 ROW 类型数据时,不能使用 UNION 操作符。但是,数据
库服务器确实支持具有 ROW 类型数据的 UNION ALL,这是因为此类运算无需排序。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值