基本sql语句--连接查询

union 联合
 
union的作用:把两次或多次查询结果合并起来。
 
典型案例:select good_id,good_name from good where shop_price>5000 or shop_price<20;
               select good_id,good_name from good where shop_price>5000 union select good_id,good_name from good where shop_price<20;
 
1.union的要求: 两次查询的列数要一致推荐:查询的每一列,相对应的列类型也一样。
 
     例如:select id,sum(num) from (select * from ta union select * from tb) as tmp group by id;
 
2.多次sql语句取出的列名可以不一致,此时以第一次sql的列名为准。
3.如果不同的语句中取出的行,有完全相同的值(每个列的值都相同),那么相同的行将会合并(去重复)。
   如果想不去重复,可以加all进行指定。
 
     例如:select * from ta union all select * from tb;
 
4.如果子句中有order by 或limit 等,需要加“()”进行括起来。推荐放到所有子句之后,即--对最终合并后的结果进行排序。
 
连接查询
 
连接查询包含:左连接(left join)、右连接(right join)、内连接(inner join)。
 
左连接:以左表为准,去右表查找数据,若在右表未找到,则用NULL补齐;(推荐使用左连接,代替右连接)
右连接:以右表为准,去左表查找数据,若在左表未找到,则用NULL补齐;
内连接:查询左右表都有的数据,即:不要左右连接中NULL的那部分。
 
如:A left join B ==== B right join A

转载于:https://www.cnblogs.com/skyline1011/p/5939522.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值