回顾

列属性:主键,自增长,唯一键。

关系:一对一,一对多,多对多

三层范式:

1NF:字段设计必须符合原子性

2NF:不存在部分依赖(没有复合主键)

3NF:不存在传递依赖(实体单独成表)

逆规范化:效率磁盘空间博弈;

高级数据操作:

新增操作:主键冲突(更新与替换),蠕虫复制

更新操作:限制更新数量:limit

删除操作:限制删除数量:limit。清空表结构:truncate

查询操作:select选项;

字段别名: 数据源(单表,多表,子查询[别名])

Where子句(条件判断:从磁盘)

Group by子句(判断结构,针对分组统计结果)

Order by子句(排序,多字段排序)

Having 子句 (判断结果,针对分组进行统计结果)

Limit子句 (限制记录数,分页)

连接查询

连接查询:将多张表(可以大于2张)进行记录的连接(按照某个指定条件进行数据拼接)

最终结果:记录数有可能变化,字段数一定会增加(至少两张表合并)

连接查询的意义:用户查看数据的时候,需要现实的数据来自多张表。

连接查询分类

Sql将连接查询分为四类:外链接,自然连接,内连接,交叉连接

连接查询:join,使用方式 左表join 右表;

左表;在join关键字左边的表;

右表:在join 关键字右边的表;

交叉连接

Cross join从一张表中循环取出每一条记录,每张记录都去另一张表进行匹配。

匹配一定保留(没有条件匹配),而连接本身字段就全增加(保留),最终会形成的结果叫做笛卡尔积

基本语法:

左表 cross join 右表;==from 左表,右表;

笛卡尔积没有意义:应该尽量避免(交叉查询没用)交叉连接的价值:保证连接结构的完整性。

例:select * from my_stu cross join my_class;

内连接:

内连接:[inner] join;

从左表中取出没一条记录去右表中所有记录进行匹配,匹配必须是某个条件,在左表中与右表中相同的最终会保留,否则不保留。

基本语法

左表 [inner] 右表 on 左表.字段=右边.字段;

On 表示连接条件;

条件字段就是代表相同的业务含义

如:内连接

Select *from my_stu a join my_class b

On a.c_id=b.id;

在php中会覆盖:

字段别名以及表别名对的使用:在查询数据的时候,不同表有同名字段,这个时候需要加上表名才能区分,而表名太长,通常使用别名。

内连接可以使用where 代替on关键字(where没有on效率高)

外链接:

外链接:outer  join ,以某张表为主,取出里面所有的记录,然后每条与另一表进行连接,不管能不能匹配上条件,最终都会保留。

能匹配,正确保留,不能匹配其他字段制空null;

外连接分为两种:以某张表为主

以左表为主: left join :左外连接

以右表为主 right join :右外连接

基本语法

左表  left/right join 右表 on 左表.字段=右表.字段;

例: select * from My_stu a left/right  join My_class  b

On a.c_id=b.id;

虽然左连接和右连接有主表差异,但是显示的结果永远是左表数据在左边,右表数据在右边,左连接和右连接可以相互转

 自然连接

Natural join :自动匹配连接条件,系统以字段名为匹配模式(同名字段作为条件,多个同名字段作为条件)

自然连接分为自然内连接。自然外连接

自然内连接 :select * from My_stu

Natural join my_class;

自然外连接 :左表 natural left/right join 右表

例:select * from my_stu natural left/right join my_class;

其实 内连接与外连接都可以模拟自然连接!!!!!!!!!

mysql学习之路_连接查询的更多相关文章

  1. mysql学习之路_联合查询与子查询

    联合查询 联合查询:将多次查询(多条select语句)在记录上进行拼接(字段不会增加). 语法:多条select语句构成,每条select语句获取的字段必须严格一致(但是字段类型无关). Select ...

  2. mysql学习之路_外键

    回顾4 连接查询: 连接多张表到一起,不管记录数如何,字段数一定会增加. 分类:内连接,外连接.自然连接,交叉连接, 交叉连接:cross join (笛卡尔积) 内连接:inner join,左右两 ...

  3. mysql学习之路_视图

    视图 视图:view是一种有结构的但是没有结构来源的虚拟表,虚拟表的结构来源不是自己定义的而是从对应的基表中产生(来源) 创建视图 基本语法: Create view 视图名字 as select 语 ...

  4. mysql学习之路_事物_存储过程_备份

    数据备份与还原 备份:将当前已有的数据保留. 还原:将已经保留的数据恢复到对应表中 为什么要做数据备份 1,防止数据丢失,被盗,误操作 2,保护数据记录 数据备份还原方式有多种:数据表备份 单表数据备 ...

  5. mysql学习之路_高级数据操作

    关系 将实体与实体的关系,反应到最终数据表的设计上来,将关系分为三种,一对多,多对多,多对多. 所有关系都是表与表之间的关系. 一对一: 一张表的一条记录一定只对应另外一张表的一条记录,反之亦然. 例 ...

  6. mysql学习之路_基础知识

                    Mysql php阶段将数据库分为三个阶 基础阶段: mysql数据库的基本操作(增删改查),以及一些高级操作(视图,触发器,函数,存储过程等),PHP操作没有sql数 ...

  7. mysql学习之路_字段类型与属性2

    字段属性: 主键,唯一键,自增长. 主键: Primary key 主要的键,一张表只能有一个字段能使用对应的键,用来唯一约束该字段里面的数据不能重复,称之为主见. 一张表最多只有一个主键. 增加主键 ...

  8. mysql学习之路_字段类型与属性

    回顾 数据库基本知识:关系型数据库与非关系型数据库 关系型数据库:安全(磁盘) 非关系型数据库:高效(内存) 关系型数据库:建立在关系模型上的数据库, 数据结构:二维表(浪费空间) 数据库操作指令:s ...

  9. mysql学习之路_乱码问题

    中文数据问题: 中文数据问题本质就说字符集问题, 计算机只识别二进制,人类识别符号:需要友谊个二进制与字符对应关系(字符集). 报错:服务器没有识别对应的四个字节. 服务器认为的数据是utf—8,一个 ...

随机推荐

  1. 干净的ssm框架项目

    其中数据库只有如下表与字段 访问效果: 项目下载: 干净的ssm框架项目.rar

  2. 将jsp页面转pdf

    网上好多思路啊,大部分都是将html转pdf,这种方法我试了很多,都不能很好地支持jsp,稍微复杂一点根本不起作用,也不知他们的博客都怎么写的,还真是应了那句话天下博客一大抄,自己都不验证的 下面说下 ...

  3. What's the #pragma pack

    What's the #pragma pack 这是一个预编译宏, 目前我对于它的认识是: 告诉编译器对于某些结构进行字节对齐使用的. 目前阶段,几乎不使用, 只是见到了, 有疑问, 先简单学习记录一 ...

  4. spirng中的asm与jdk不兼容<已解决>

    转载自:spirng中的asm与jdk不兼容<已解决> 前言 不知道前面对eclipse做了什么,使用maven来创建项目,然后转成web,启动的时候一直报错.我弄了好久,还是无法解决,先 ...

  5. bowtie:短序列比对的新工具

    bowtie:短序列比对的新工具(转) (2014-11-17 22:15:24) 转载▼ 标签: 转载   原文地址:bowtie:短序列比对的新工具(转)作者:玉琪星兆 Bowtie是一个超级快速 ...

  6. 可迭代对象(Iterable)和迭代器(Iterator)

     迭代是访问集合元素的一种方式. 迭代器是一个可以记住遍历的位置的对象. 迭代器对象从集合的第一 个元素开始访问,直到所有的元素被访问完结束.迭代器只能往前不会后退. 1. 可迭代对象 以直接作用于 ...

  7. Luogu 2051[AHOI2009]中国象棋 - DP

    Description 在 $n * m$ 的格子上放若干个炮, 使得每个炮都不能攻击到其他炮 Solution 定义数组f[ i ][ j ][ k ] 表示到了第 i 行, 已经有2个炮的列数为 ...

  8. ubuntu 下通过ftp命令下载文件

    /*连接*/ $ ftp 192.168.180.2Connected to 192.168.180.2.Name (192.168.180.2:rivsidn): admin  Password: ...

  9. 20岁的设计师vs30岁的设计师

    20岁的设计师vs30岁的设计师 如果你还是20来岁,要恭喜你,你还年轻, 一切才刚刚开始 还有时间去探索无尽的可能 还有时间去找到无限的前途 ​ 如果30岁的你还不够强大, 请记得时刻给予自己信心, ...

  10. JDK 之 Java Bean 内省机制

    JDK 之 Java Bean 内省机制 JDK 规范目录(https://www.cnblogs.com/binarylei/p/10200503.html) JavaBean 是一种特殊的 Jav ...