Left join:即左连接,是以左表为基础,根据ON后给出的两表的条件将两表连接起来。结果会将左表所有的查询信息列出,而右表只列出ON后条件与左表满足的部分。左连接全称为左外连接,是外连接的一种。
Right join:即右连接,是以右表为基础,根据ON后给出的两表的条件将两表连接起来。结果会将右表所有的查询信息列出,而左表只列出ON后条件与右表满足的部分。右连接全称为右外连接,是外连接的一种。
Inner join:即内连接,同时将两表作为参考对象,根据ON后给出的两表的条件将两表连接起来。结果则是两表同时满足ON后的条件的部分才会列出。
先看Left join:
应用场景:商城商品列表需要显示分类的名称:
(1).shop_category分类表 id(分类id) catename(分类名) 1 手机 2 电脑 (2).shop_goods商品表 id(商品id) cateid(分类ID) title(商品名称) 1 1 小米5 2 1 小米6 3 1 苹果6 4 2 三星c201 5 2 戴尔n4050 9 3 充电宝1
SQL执行:
select * from shop_goods as a left join shop_category as b on a.cateid=b.id
执行结果:
id(商品id) cateid(分类ID) title(商品名称) catename(分类名) 1 1 小米5 手机 2 1 小米6 手机 3 1 苹果6 手机 4 2 三星c201 电脑 5 2 戴尔n4050 电脑 9 3 充电宝1 Null
这样就完成了商品列表的显示,left join在查询中无法匹配的用Null来填充.我们利用PHP判断catename是Null显示“商品分类不存在或已被删除即可”;
再看Right join:
Right join和Left join区别不大,实现 Right join的2种方法:
(1).修改上面的SQL语句中表的位置
(2).将上面的SQL中的Left join改为Right join
最后再看Inner join:
Inner join具有排他性,烦是无法满足条件的全部排出,例如left join中无法匹配的都是会显示Null,但是 Inner join直接不显示本条记录。
同样上面的表我们执行SQL:
select * from shop_goods as a inner join shop_category as b on a.cateid=b.id
执行结果:
id(商品id) cateid(分类ID) title(商品名称) catename(分类名) 1 1 小米5 手机 2 1 小米6 手机 3 1 苹果6 手机 4 2 三星c201 电脑 5 2 戴尔n4050 电脑
Inner join已经将无法匹配的栏目的商品直接不显示,直接排除
三者的关系图如下:
where与having非常类似.都能筛选数据.表达式完全一致. 但是职责的确不同.where负责对表中的字段进行筛选,having负责对where筛选后的结果集再次筛选。这也就是where不能使用别名字段来筛选的原因,因为数据中没有这个字段。&n...
例如我们需要查询商品表中每个分类中商品id最大的记录,并且显示商品价格以下是表结构:id catename title &nb...
项目和第三方系统对接,由于第三方开发人员属于兼职,数据库结构不一致的问题只能我来处理。此处文章用本地模拟演示。数据库资料:1号服务器: 账号root 密码root IP:127.0.0.1 数据库名称:data1 2号服务器...
概述: 目前我们的表设计,最高级别的范式是6NF,对于PHP程序员而言,我们的表满足3NF即可(范式即规范)【一】1NF (1).所谓1NF,就是指标的属性具有原子性,即表的列不能再分割,不能分割意思是字段本身的含义(例如address字段不能再分割)...
已有表名log来记录用户日志,id是主键,uid是用户id,rmk是备注,addtime是时间戳,需要取出不重复的用户日志记录默认的结果集:id uid rmk ...
现在有张表products是产品表,vend_id是供应商id,prod_price是供应价格,现在需要统计每个供应商供应了多少商品,供应商品的平均价格,sql如下:SELECT vend_id, AVG( prod_price ), COUNT( * ...