• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase
您的位置:首页 > 数据库 >Mysql > 深入sql多表差异化联合查询的问题详解

深入sql多表差异化联合查询的问题详解

作者: 字体:[增加 减小] 来源:互联网 时间:2017-05-11

通过本文主要向大家介绍了java实现多表查询,excel多表数据查询,excel表格多表汇总,excel多表联动,excel如何多表汇总等相关知识,希望本文的分享对您有所帮助

本章简略讲述本人在实例开发中遇到的多表查询的问题
其中主要讲述
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)来实现我们需要的效果。
有兴趣的同学可以自己操作一下,验证下两种方法的不同。

</div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • 深入sql多表差异化联合查询的问题详解

相关文章

  • 2017-05-11mysql 常用数据库语句 小练习
  • 2017-05-11mysql 读写分离(实战篇)
  • 2017-05-11MySQL数据库的23个注意事项
  • 2018-12-05mysql远程机器导入导出数据 锁表不锁表 部分数据或全部
  • 2018-12-05如何学习MySQL?MySQL中update使用以及MySQL更新
  • 2018-12-05一列保存多个ID(将多个用逗号隔开的ID转换成用逗号隔开的名称)
  • 2018-12-05MySQL视图的作用详解(二)-过滤数据、计算字段、更新视图
  • 2018-12-05mysql智能存储过程
  • 2017-05-11MySql日期查询语句详解
  • 2018-12-05轻松掌握MySQL函数中的last_insert_id()

文章分类

  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase

最近更新的内容

    • 数据库中的内容字段被挂马的替换方法 SQL注入
    • mySql学习笔记:比sql server书写要简单
    • Mysql中limit的用法详解
    • MySQL高级二——流程控制语句
    • Linux环境下mysql5.7.13安装教程_MySQL
    • MySQL数学函数简明总结
    • 删除重复记录,并且剩下一条
    • MySQL之-基于Amoeba实现读写分离详解(图文)
    • MySQL5.0.16的乱码问题解决方案
    • mysql SKIP-NAME-RESOLVE 错误的使用时机造成用户权限

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有