联合查询

union联合查询

语法:

    select 语句 union 【all|distinct】 select 语句;

示例:

特点:

    条件:两表的查询出来的字段数目必须相同

    字段上会不会进行拼接

    只有在记录上对两个表查询出来的结果进行联合。

 

【all|distinct】

all            显示所有的记录,包含重复

distinct        (缺省)不显示结果集中的重复记录

示例:

作用:

    1、对一个大的数据表进行分表存储,联合查询。

    2、对于同一个表实现不同的需求

需求:对学生表sex=1按年龄降序,sex=0的按年龄升序

连接查询

    由于数据库每一个表存储一个实体信息,实体之间还有联系。根据需求,经常会对具有关系的实体表进行,连接查询。

    连接查询实现的,结果集中的字段数增加,记录数不增加。

连接查询分

cross join

交差连接

语法:

    select * 或字段列表 from 表A cross join表B 【where条件】;

示例:

    

说明:

    结果是一个迪卡尔积,

示例:

使用条件进行连接

演示:

    将stu表中的id为12的记录c_id设置为null(也不是与班级表不匹配)

说明:

    最终的结果少了一个学生的信息。

内连接

inner join

语法:

    select *或字段列表 from 表A 【inner】 join 表B【where子句】;

说明:

    如果内连接没有指定条件,那么结果也是一个迪卡尔积

示例1:

 

外连接

    外连接分为左外连接与右外连接,如果以左边的表为主表那么就叫左外连接;如果以右边的表为主表,那么就叫右外连接。

左外连接

    left join

语法:

    select *或字段列表 from 表A left join 表B on 条件;

示例:

原理:

    1、在内存中产生两个结果集

    2、进行连接

    2.1、使用主表中的第1条记录,去匹配从表中的第1条记录,判断条件是否匹配,如果匹配,将两个表的记录连接在一起保留。如果不成功,保留主表的字段,从表的字段置null

    2.2、使用主表中的第1条记录,去匹配从表中的第2条记录,判断条件是否匹配,如果匹配,将两个表的记录连接在一起保留。如果不成功,保留主表的字段,从表的字段置null

    2.3、使用主表中的第1条记录,去匹配从表中的第3条记录,判断条件是否匹配,如果匹配,将两个表的记录连接在一起保留。如果不成功,保留主表的字段,从表的字段置null

    3、主表中的第1条记录匹配完成后,再使用主表的第2条记录,依次进行匹配。

    。。。。。。

右外连接

    right join

 

内连与外连的区别:

1、内连可以省略条件。

2、外连必须使用条件。

3、内连时,如果条件不匹配,丢弃。

4、外连时,如果条件不匹配,也会保留主表中的字段。从表中的置null

自然连接

    自动根据表中的同名字段作为匹配条件。

nature join

语法:

    select *或字段列表 from 表A natural join 表B;

    自然左外连接

    select *或字段列表 from 表A natural left join 表B where

    自然右外连接

    select *或字段列表 from 表A natural rightjoin 表B where

 

示例:

Mysql的联合查询的更多相关文章

  1. mysql中联合查询

    联合查询union 一个翻译问题的解释: 在mysql的手册中,将连接查询(Join)翻译为联合查询: 而联合查询(union),没有明确翻译. 但: 在通常的书籍或文章中,join被翻译为“连接”查 ...

  2. php+mysql数据库联合查询 left join 右侧数据重复问题

    情况:多表联合查询(三表及以上联合查询) 分析: A left join B left join C left join D 假如: 表B.C.D都与表A关联查询 A left join B 4条数据 ...

  3. MySQL 中联合查询效率分析

    目前我有两个表,一个keywords和一个news表.keyword存放关键词是从news中提取,通newsid进行关联,两表关系如图: keywords中存有20万条数据,news中有2万条数据,现 ...

  4. mysql三表联合查询,结果集合并

    参考: mysql 结果集去重复值并合并成一行 SQL 三表联查 数据库三表连接查询怎么做 合并: MySQL中group_concat函数 完整的语法如下: group_concat([DISTIN ...

  5. mysql及联合查询

    SQL语句分类 DDL 数据库定义语言 定义数据库对象 create alter truncate drop TPL 事务处理语言 rollback commit DCL 数据控制语言 由 GRANT ...

  6. mysql:联合查询

    SELECT t1.name, t2.salary  FROM employee AS t1 INNER JOIN info AS t2 ON t1.name = t2.name; 可以对数据表使用别 ...

  7. MYSQL的联合查询最好是少用,效能差异巨大

    同样的功能,不同的写法,时间和内存占用差了几千倍,不废话,直接上代码 第一种写法: 代码如下: $Rs=DB::get($_ENV['DB'],3,"SELECT * FROM _xiazh ...

  8. thinkphp 使用原生mysql语句 联合查询

    <?php class DelAction extends Action { public function ml(){ // 实例化一个空模型,没有对应任何数据表 $Dao = M(); // ...

  9. mysql三表联合查询

    -- SELECT d.userId, d.userPhoNum, a.orderId, a.productType, b.courseId, b.courseName, c.payJe -- FRO ...

随机推荐

  1. 【Stage3D学习笔记续】山寨Starling(二):VertexData探幽

    还记得之前的学习笔记中我们的顶点缓冲数组中的顶点数据么,我们使用一个一维数组来记录所有的顶点数据,这是由于顶点缓冲上传数据时是使用的一维数组. 如果对顶点数据进行一层代码的封装,就能更加的方便我们来操 ...

  2. iOS_城市定位

    技术点-利用CoreLoaction框架,实现城市定位功能. 原理: 利用苹果官方提供的CoreLocation框架实现城市定位的功能: 该框架主要包括两个比较有用的类:定位类CLLocationMa ...

  3. Flash 无法输入中文的修正方法

    在某些运行模式或运行时环境中,Flash 有一个 Bug,文本框与键盘的交互模式会无法输入中文(包括日文等带有输入法状态栏的输入模式),只要对 TextField 文本框实例的 FocusEvent. ...

  4. [React Native] Build a Github Repositories component

    Nav to Repos component from Dashboard.js: goToRepos(){ api.getRepos(this.props.userInfo.login) .then ...

  5. [MODx] Build a CMP (Custom manager page) using MIGX in MODX 2.3 -- 2

    We are not finishing yet... 1. Under MIGX Management, we need to add some "Actionbuttons" ...

  6. 使用日志服务LogHub替换Kafka

    https://yq.aliyun.com/articles/35979#index_section

  7. QT5中如何自定义窗口部件

    提升法 eg.(定义一个新的QLable部件)1.定义一个类class Label : public base, public QLabel //可以支持多重继承2.在qt creator中打开ui编 ...

  8. Android界面刷新

    Android的invalidate与postInvalidate都是用来刷新界面的,用法区别在于: 1)invalidate():实例化一个Handler对象,并重写handleMessage方法调 ...

  9. ios存储 plist 偏好设置 自定义对象存储

    1,plist Plist注意:不能存储自定义对象 Plist:数组和字典,  如何判断一个对象能不能使用Plist,就看下有没有writeToFile 获取应用的文件夹(应用沙盒) NSString ...

  10. C语言---翻译过程

    c的实现中包括两种环境: 1.翻译环境(translation environment):源程序---->机器指令 2.执行环境(execution environment):执行机器指令 这两 ...