深入sql多表差异化联合查询的问题详解
本章简略讲述本人在实例开发中遇到的多表查询的问题
其中主要讲述
select a.*,b.*,c.* from a,b,c
和
select a.*,b.*,c.* from 表a inner join 表b on a.id=b.id inner join 表c on a.code=c.code
的区别
最近遇到一个这样的项目需求——要求页面集合显示三个关联表的信息。
由于实际项目里出现的字段比较多,现在简化说明如下:
table a 含有字段 username,cardcode,itamcode
table b 含有字段 cardcode,cardname
table c 含有字段 itamcode,itamname
其中界面要在一个数据集里同时出现username,cardname,itamname
话说虽然学过sql 内联,外联的问题,但是以前的项目基本出现的都是两个表的关联实现,现在是第一次用到超过两个表的关联实现问题。在百度找了一下资料,才发现原来基本原理是一样的。哈,本人去年才入职,经验不足,大神们,请别见笑哈!
呃,如果读者暂时还不熟悉sql基本内联,外联的相关知识,请自觉找度娘面壁去哈,笔者在这里不熬述了。长话短说,现在进入正题……
发现要实现上面的功能有两种方法,分别是
select a.username,b.cardname,c.itamname from a,b,c
和
select a.username,b.cardname,c.itamname from 表a inner join 表b on a.cardcode=b.cardcode inner join 表c on a.itamcode=c.itamcode
(如果字段是差异化的话,可以略写表名)
就上面的语法来说,其实两种实现方法的效果是一样的,但如果真要较真细说优劣的话,还是第二种实现方法比较实用的。
用inner join(全外联)的写法, 不仅可以按照实际需求*转化left join(左外联)和right join(右外联),而且注明了结合的顺序, 特别是支持了sql文优化的方便。
还有一个就是说当我某个字段可以为null的时候,第一种查询方法得出的值其实是不完全的。比如说我上面的例子中当table c 的itanname 并非必填的时候,只能通过左外连接(left join)来实现我们需要的效果。
有兴趣的同学可以自己操作一下,验证下两种方法的不同。
上一篇: PHP线程的内存回收问题
下一篇: thinkcmf5与宝塔
推荐阅读