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已经将无法匹配的栏目的商品直接不显示,直接排除
三者的关系图如下:

我们从一个结果集中查询信息一般都是select * from (select...),每次都要编写from (select...)非常麻烦,于是我们将结果集保存起来,这就是视图的便利。创建视图的命令为:create view &nb...
海量表,数据量较大,并且每个字段的值具有唯一性。如果你创建的海量表只是数据多,索引是毫无意义的。构建海量时我们要使用存储过程。学习自韩顺平(1).创建一个测试数据库create database testdb;set names gbk;use testdb(2).创建dep...
在项目中发现大量的form连接表,就开始质疑inner join 和 form a,b的性能问题。找到一份有价值的资料,特别记录:ANSI SQL规范首选INNER JOIN语法。此外,尽管使用WHERE子句定义联结的确比较简单,但是使用明确的联结语法能够确保不会忘记联结条件,有时候这样做也能影响性...
项目中查询数据部分字段出现null,影响到了排序,但是由于没有数据库权限,还想将null转为其他值表示;例如现有表member的原始数据:SELECT * FROM memberid &n...
(1).下面是一张基本的会员表membermid name age 1 高峰 24 2 王小 19 3 韩星 24(2).下面是一张基本的会员日志表loglid ...
_通配符只匹配单个字符。假如products表存在以下数据: 需要匹配到prod_nameprod_id prod_name JP1000 JetPack 1000 JP2000 JetPack 2000SQL语句: SE...