Mysql学习MySQL中union和join语句使用区别的辨析教程
《Mysql学习MySQL中union和join语句使用区别的辨析教程》要点: MYSQL入门union和join是需要联合多张表时常见的关联词,具体概念我就不说了,想知道上网查就行,因为我也记不准确. MYSQL入门
select * from tmp_libingxue_a;
name number
libingxue 1001
yuwen 1002
select * from tmp_libingxue_b;
name number
libingxue 1001
feiyao 1003
select * from tmp_libingxue_a union select * from tmp_libingxue_b;
libingxue 1001
yuwen 1002
feiyao 1003
select * from tmp_libingxue_a union all select * from tmp_libingxue_b;
libingxue 1001
yuwen 1002
libingxue 1001
feiyao 1003
MYSQL入门但是这样在hive里面是不能执行的,执行select * from tmp_libingxue_a union all select * from tmp_libingxue_b;会failed,hive中union必须在子查询中进行.如 MYSQL入门
select * from (select * from tmp_yuwen_a union all select * from tmp_yuwen_b) t1;
MYSQL入门注意,必须是union all,单独用union它会提示你缺少ALL,而且后面的t1必须写,你可以写成a或者b,但是一定要写,不写会出错. MYSQL入门
select * from (select * from tmp_yuwen_a)t1 join (select * from tmp_yuwen_b) t2;
select * from tmp_yuwen_a t1 join (select * from tmp_yuwen_b) t2;
MYSQL入门left outer join和right outer join用法类似,区别就是left outer join会把左边表的字段全部选择出来,右边表的字段把符合条件的也选择出来,不满足的全部置空,也就是说以左边表为参照.right outer join同理以右边表为参照.这三个join之间的差别说过很多次,网上也有更详细的解释,不再赘述. MYSQL入门
drop table tmp_libingxue_resource;
create external table if not exists tmp_libingxue_resource(
user_id string,shop_id string,auction_id string,search_time string
)partitioned by (pt string)
row format delimited fields terminated by 't'
lines terminated by 'n'
stored as sequencefile;
drop table tmp_libingxue_result;
create external table if not exists tmp_libingxue_result(
user_id string,search_time string
)partitioned by (pt string)
row format delimited fields terminated by 't'
lines terminated by 'n'
stored as sequencefile;
insert overwrite table tmp_libingxue_result where(pt=20041104) select * from tmp_libingxue_resource;
MYSQL入门
sudo -u taobao hadoop dfs -rmr /group/tbads/warehouse/tmp_libingxue_result/pt=20041104
sudo -u taobao hadoop jar /home/taobao/dataqa/framework/DailyReport.jar com.alimama.loganalyzer.tool.SeqFileLoader tmp_libingxue_resource.txt hdfs://v039182.sqa.cm4:54310/group/tbads/warehouse/tmp_libingxue_result/pt=20041104/part-00000
MYSQL入门
hive> select * from tmp_libingxue_resource;
MYSQL入门
OK
2001 0 11 101 20041104
2002 0 11 102 20041104
MYSQL入门
hive> select * from tmp_libingxue_result;
MYSQL入门
OK
2001 0 12 103 20041104
2002 0 12 104 20041104
MYSQL入门
select user_id,shop_id,max(auction_id),max(search_time)
from
(select * from tmp_libingxue_resource
union all
select * from tmp_libingxue_result )t1
group by user_id,shop_id;
MYSQL入门
2001 0 12 103
2002 0 12 104
MYSQL入门
select t1.user_id,t1.shop_id,t2.auction_id,t2.search_time
from
(select * from tmp_libingxue_resource) t1
join
(select * from tmp_libingxue_result) t2
on t1.user_id=t2.user_id and t1.shop_id=t2.shop_id;
MYSQL入门
2001 0 12 103
2002 0 12 104
通过前面的介绍,使用UNION对表的结果集进行并运算与使用JOIN对多表进行连接,二者有本质的不同. 下面给出一个使用UNION运算符连接二表记录的运算实例. 典型的二表记录的UNION运算 MYSQL入门假定有两个表Table3和Table4,其包含的列和数据分别如下所示. MYSQL入门Table1数据库表 MYSQL入门 MYSQL入门Table2数据库表 MYSQL入门 MYSQL入门Table1表和Table2表具有相同的列结构,因此可以使用UNION运算符连接两个表的记录集,得到的连接结果如下表所示. MYSQL入门使用UNION连接Table3表和Table4表的记录 MYSQL入门 MYSQL入门上述连接过程的实现代码可表示如下: MYSQL入门
SELECT *
FROM Table1
UNION
SELECT *
FROM Table2
《Mysql学习MySQL中union和join语句使用区别的辨析教程》是否对您有启发,欢迎查看更多与《Mysql学习MySQL中union和join语句使用区别的辨析教程》相关教程,学精学透。编程之家PHP学院为您提供精彩教程。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |