【SQL查询】集合查询之INTERSECT
来源:互联网 发布:sper.getlength java 编辑:程序博客网 时间:2024/05/09 11:18
1 BLOG文档结构图
2 前言部分
2.1 导读和注意事项
各位技术爱好者,看完本文后,你可以掌握如下的技能,也可以学到一些其它你所不知道的知识,~O(∩_∩)O~:
① 集合查询之INTERSECT的使用
Tips:
① 本文在itpub(http://blog.itpub.net/26736162)、博客园(http://www.cnblogs.com/lhrbest)和微信公众号(xiaomaimiaolhr)上有同步更新。
② 文章中用到的所有代码、相关软件、相关资料及本文的pdf版本都请前往小麦苗的云盘下载,小麦苗的云盘地址见:http://blog.itpub.net/26736162/viewspace-1624453/。
③ 若网页文章代码格式有错乱,请下载pdf格式的文档来阅读。
④ 在本篇BLOG中,代码输出部分一般放在一行一列的表格中。其中,需要特别关注的地方我都用灰色背景和粉红色字体来表示,比如在下边的例子中,thread 1的最大归档日志号为33,thread 2的最大归档日志号为43是需要特别关注的地方;而命令一般使用黄色背景和红色字体标注;对代码或代码输出部分的注释一般采用蓝色字体表示。
List of Archived Logs in backup set 11
Thrd Seq Low SCN Low Time Next SCN Next Time
---- ------- ---------- ------------------- ---------- ---------
1 32 1621589 2015-05-29 11:09:52 1625242 2015-05-29 11:15:48
1 33 1625242 2015-05-29 11:15:48 1625293 2015-05-29 11:15:58
2 42 1613951 2015-05-29 10:41:18 1625245 2015-05-29 11:15:49
2 43 1625245 2015-05-29 11:15:49 1625253 2015-05-29 11:15:53
[ZHLHRDB1:root]:/>lsvg -o
T_XLHRD_APP1_vg
rootvg
[ZHLHRDB1:root]:/>
00:27:22 SQL> alter tablespace idxtbs read write;
====》2097152*512/1024/1024/1024=1G
本文如有错误或不完善的地方请大家多多指正,ITPUB留言或QQ皆可,您的批评指正是我写作的最大动力。
2.2 本文简介
最近心情很低落,今天又下雨,本来想着睡到12点的,结果一发小打电话过来,聊了聊近况,然后问了一道SQL的面试题,这对我而言都是最简单的查询。由于发小是刚入IT行业,准备找Java的工作,所以心里还是担心他是否听懂我的意思了,稳妥起见,还是自己写段代码发他吧。在这里也预祝发小可以顺利找到自己心仪的工作。
发小的问题是:如何找出2张表中的相同数据然后插入到第三张空表中?这个面试题的解答有多种办法,但是最直接也最简单的方式就是集合查询,利用INTERSECT这个交集查询就可以了。下面是整个实验过程。
第二章 实验部分
SQL> CREATE TABLE T_A (ID NUMBER,NAME VARCHAR2(5));
Table created.
SQL> CREATE TABLE T_B (ID NUMBER,NAME VARCHAR2(5));
Table created.
SQL> CREATE TABLE T_C (ID NUMBER,NAME VARCHAR2(5));
Table created.
SQL> INSERT INTO T_A VALUES(1,'a');
1 row created.
SQL> INSERT INTO T_A VALUES(2,'b');
1 row created.
SQL> INSERT INTO T_A VALUES(3,'c');
1 row created.
SQL> INSERT INTO T_A VALUES(4,'d');
1 row created.
SQL> INSERT INTO T_A VALUES(5,'e');
1 row created.
SQL> INSERT INTO T_B VALUES(3,'c');
1 row created.
SQL> INSERT INTO T_B VALUES(4,'d');
1 row created.
SQL> INSERT INTO T_B VALUES(6,'f');
1 row created.
SQL> INSERT INTO T_B VALUES(7,'g');
1 row created.
SQL> commit;
Commit complete.
SQL> SELECT * FROM T_C;
no rows selected
SQL> INSERT INTO T_C
2 SELECT ID ,NAME FROM T_A
3 INTERSECT
4 SELECT ID ,NAME FROM T_B;
2 rows created.
SQL> COMMIT;
Commit complete.
SQL> SELECT * FROM T_C;
ID NAME
---------- -----
3 c
4 d
SQL>
第三章 实验中用到的SQL总结
DROP TABLE T_A;
DROP TABLE T_B;
DROP TABLE T_C;
CREATE TABLE T_A (ID NUMBER,NAME VARCHAR2(5));
CREATE TABLE T_B (ID NUMBER,NAME VARCHAR2(5));
CREATE TABLE T_C (ID NUMBER,NAME VARCHAR2(5));
INSERT INTO T_A VALUES(1,'a');
INSERT INTO T_A VALUES(2,'b');
INSERT INTO T_A VALUES(3,'c');
INSERT INTO T_A VALUES(4,'d');
INSERT INTO T_A VALUES(5,'e');
INSERT INTO T_B VALUES(3,'c');
INSERT INTO T_B VALUES(4,'d');
INSERT INTO T_B VALUES(6,'f');
INSERT INTO T_B VALUES(7,'g');
commit;
INSERT INTO T_C
SELECT ID ,NAME FROM T_A
INTERSECT
SELECT ID ,NAME FROM T_B;
About Me
...............................................................................................................................
● 本文作者:小麦苗,只专注于数据库的技术,更注重技术的运用
- 【SQL查询】集合查询之INTERSECT
- 【Oracle sql基础】多表查询中的集合操作union all、union、intersect、minus
- SQL集合查询
- SQL 查询集合
- SQL 查询中的并(Union)、交(Intersect)、差(Minus)
- oracle之集合查询
- SQL 语句(五)--------------数据查询(集合查询)
- Hibernate查询之SQL查询
- SQL查询之模糊查询
- SQL查询之组合查询
- SQL查询语句整理集合
- SQL Server T-SQL高级查询,sql 查询集合
- 使用 UNION、INTERSECT 和 EXCEPT 对查询结果执行集合运算
- ORACLE集合操作符号UNION、UNION ALL、INTERSECT、MINUS来进行查询结果的合并操作
- sql之查询
- SQL语句之查询
- SQL之模糊查询
- SQL之连接查询
- (四)基于myeclipse的RocketMQ--Demo实践
- hdoj-【2049 不容易系列之(4)——考新郎】
- 基于U3D的VR开发教程:(3)基础场景搭建
- js对象无法当成参数传递
- Java Thread Dump 日志分析
- 【SQL查询】集合查询之INTERSECT
- java web 前端开发框架和流程
- Java switch-case 语句的优点和几点注意事项
- 组合模式(Composite)
- ELM实验思路
- [JS]JS中call/apply/bind方法总结
- Fragment常用操作的生命周期切换展示
- 第十四周项目3折腾二维数组
- 判断母字符串是否含子字符串。