引入

当我们在数据库中创建表的时候,有可能某些列中值内容量很大,而且重复。

例子:创建一个学生表,按学校年纪班级分,表的内容大致如下:

id name partment
1 xxx x学校x年级x班级
2 ooo x学校x年级x班级
3 zzz z学校x年级x班级
4 ddd y学校x年级x班级

我们看出来对应的partment对应的值很长,而且重复量很大,这样就很不合适。

因此我们考虑将复杂重复的部分单独拿出来分成2个表:

第一张表:

id caption
1 x学校x年级x班级
2 y学校x年级x班级
3 z学校x年级x班级

第二张表在之前的基础上修改的:

id name partment
1 xxx 1
2 ooo 2
3 zzz 3
4 ddd 1

这样看起来就很简洁了,我们将很长的且重复的部分拿出来,然后规定编号,创建学生表的时候,学生对应的partment只需要取学校对应的id便可,这样同时这2张表也就会关联起来。

说明:

1、他们的关联关系;表2中的partment和表1的id联系再一起。

2、表一的数据会对应表2中的多条数据,这就叫一对多

问题:此时,两张表是相对独立的,都可以各自插入自己的数据,这样做很合适的,并没实质行的关联?

因此,必须要将其限制。表二的partment数据必须是表一中有的,不然,就不让其增加。

这里(partment)就引入了一个名词 —- 外键

外键

说明:
1、外键:一个表接收另一个表的主键。
2、partment外键的是表一中的nid。
3、当我们创建了外键,则系统变默认会为我们添加,相应的约束,如:表二中的partment数据必须是表一中nid有的;表二和表一就关联起来了。

Navicat创建外键

创建part表:

创建person表:

外键的创建注意点:
创建外键时,互相对应的表中的数据类型必须一样

创建外键

1、首先在要创建外键的表上右键,选设计表。
2、进入设计表,在右边显示表行信息,然后点击外键:

3、选择字段,会出现一个选择框,选择你要设置外键的列;

4、选择参考表,选择要外键要关联的表,

说明:
参数数据库:因为两个数据库在同意目录下,所以这里可以不用选择;默认是同目录下的。

5、选择参考字段;选择参考表中要设为外键的列;

注意:
外键的创建,连个表中关联的列的数据类型必须一样,不然不能成功。

6、保存CTRL + S

使用外键

此时part中没有数据,如果此时你在person中添加数据,结果:

在part中添加数据,结果:

此时再在,person中添加数据:

注意:

这里不能输入part中nid没有的值,不然也会报错。

SQL命令创建外键

创建part:

create table part(
nid int not null auto_increment primary key,
caption varchar(32) not null
)

part

创建person:

create table person(
nid int not null auto_increment,
name varchar(32) default null,
email varchar(32) default null,
part_nid int,
primary key(nid),
constraint fk_person_part foreign key (part_nid) references part(nid)
)

person

创建完之后外键对应代码的关系:

分析:
1、从名字可以看出代码对应的是什么位置的。
2、图中名(C对应代码中的CONSTRAINT)这行可以不用设,系统会默认帮我设置,但是最好设置,如果要删除外键的时候,就可以通过这个名字进行相应的操作

代码删除外键

alter table person1 drop foreign key fk_person1_part1;

代码增加外键

alter table person1 add constraint fk_p1_t1 foreign key (part1_nid) references part1(nid);

通过外键进行数据操作

part表:

person表:

需求:要找出person表中属于x学校的人?

1、之前学的办法:

  • 1、先去part中获取x对应的nid
  • 2、然后再通过这个nid与parson中part_id对用的关系,查找出对应的name
select name from person where part_id in (select nid form part where caption = "x")

2、链表方法 left join

left join

使用连表提供的方法,left join操作代码:

select * from person left join part on person.part_id = part.nid

结果显示:

分析:
left join:相当于将part表匹配的部分直接移动到person的列后面,组合起来显示。

既然内容都合并了,那么此时我们再加上判断,就可以将要的数据获取了。

代码1:

select * from person left join part on person.part_id = part.nid where part.caption = "x"

结果:

说明:

之前我们用的 * 获取的是全部的信息,如果我们获取指定的信息,可以将其修改。

如:只获取person的name代码:

select person.name from person left join part on person.part_id = part.nid where part.caption = "x"

结果:

注意:
join连接的条件,使用 on 进行对接的,条件写在on后面。

A left join B on a.xx = b.xx

left join的特点:
1、以A为主
2、将A中的所有数据罗列
3、B则只显示与A相对应的数据

问题:验证我们说的谁在前就谁为主,谁的数据就全部显示,我们将person和part换个位置?

select * from part left join person on person.part_id = part.nid;

结果:

right join

在谁显示所有数据的上来看,他和left join刚好相反,以后面的表为主,显示其所有的数据。

inner join

会将没有建立关系的数据忽略掉。不管谁在前,结果都是一样。

select * from person inner join part on person.part_id = part.nid;

结果:

总结:
1、这几个join可以写多个的,意思就是一个表可以同时有多个外键。

2、当选择的列名,是所有表中唯一的话,可以不用写前缀的表名。如:person.part_id就可以直接写成part_id.

3、上面的part表,有个别名叫,字典表

MySQL连表操作之一对多的更多相关文章

  1. MySQL 数据表操作

    MySQL 数据表操作 创建MySQL数据表需要以下信息: -表名: -表字段名: -定义每个表字段: 一.创建数据表 1)mysql> create  table  table_name (c ...

  2. Database学习 - mysql 数据库 表操作

    mysql 数据库 表操作 创建数据表 基本语法格式: 创建数据表: create table 表名( 字段名 datatype 约束, 字段名 datatype 约束, ...... ) 修改表名 ...

  3. mysql 数据表操作 目录

    mysql 数据表操作 存储引擎介绍 mysql 使用存储引擎 mysql 数据表的增删改查 mysql 数据类型 mysql 约束条件

  4. 数据库 MySQL 之 表操作、存储引擎

    数据库 MySQL 之 表操作.存储引擎 浏览目录 创建(复制) 删除 修改 查询 存储引擎介绍 一.创建(复制) 1.语法: 1 2 3 4 5 CREATE TABLE 表名(     字段名1 ...

  5. Mysql 库表操作初识

    Mysql 库表操作初识 终端登录mysql 这里只演示win下, cmd 终端. 至于怎么在win下, linux, mac安装, 感觉这是一个入门级的百度搜索问题, 安装都搞不定, 确实有点尴尬, ...

  6. mysql连表操作是先连表还是先查询条件

    mysql连表操作是先连表还是先查询条件 一.总结 一句话总结: 连表操作时:先根据查询条件和查询字段确定驱动表,确定驱动表之后就可以开始连表操作了,然后再在缓存结果中根据查询条件找符合条件的数据 1 ...

  7. MySQL<多表操作>

    多表操作 外键 什么是外键 外键是指引用另一个表中的一列或多列,被引用的列应该具有主键约束或唯一性约束. 外键用于建立和加强两个表数据之间的链接. 为表添加外键约束 想要真正连接两个表的数据,就需要为 ...

  8. Django框架第七篇(模型层)--多表操作:一对多/多对多增删改,跨表查询(基于对象、基于双下划线跨表查询),聚合查询,分组查询,F查询与Q查询

    一.多表操作 一对多字段的增删改(book表和publish表是一对多关系,publish_id字段) 增  create publish_id 传数字   (publish_id是数据库显示的字段名 ...

  9. mysql单表操作与多表操作

    0. null和notnull: 使用null的时候: create table t8( id int auto_increment primary key, name varchar(32), em ...

随机推荐

  1. iOS开发之功能模块--根据需求开发横向的子弹盒View

    这个需求是本人工作开发中后期需求要添加的新功能,本人模仿UITableView的代理和数据源方法进行了第一阶段的开发.第二阶段是添加丰富的动画. 这个功能需求描述:能上传添加五个待选头像,五个头像分别 ...

  2. 配置git同时push到两个远端库的简单方法

    最近在写一个开源的论坛系统,在发布代码时选择了github和coding这两个平台,我手懒,不想敲两次git push了,所以说突然有了一个很奇怪的需求:用一条git push同时push到两个远端代 ...

  3. C# 中的var关键字

    var 是3.5新出的一个定义变量的类型 其实也就是弱化类型的定义 VAR可代替任何类型 编译器会根据上下文来判断你到底是想用什么类型的 至于什么情况下用到VAR 我想就是你无法确定自己将用的是什么类 ...

  4. C#如何使用Soap协议调用WebService?

    WebService是什么?它的作用? WebService是一个平台独立.低耦合的.自包含的.基于可编程的可使用xml描述.调用的web应用程序,用于开发分布式的交互式的应用程序. Soap是什么? ...

  5. redis、memcache、mongoDB 做了对比

    from: http://yang.u85.us/memcache_redis_mongodb.pdf   从以下几个维度,对redis.memcache.mongoDB 做了对比. 1.性能 都比较 ...

  6. Cookie无法读取

    问题描述:用谷歌调试可以看到,但是用js去读取的时候,一直提示undefined

  7. [转]教你一招 - 如何给nopcommerce增加一个类似admin的area

    本文转自:http://www.cnblogs.com/wucf2004/p/nopcommerce-area.html asp.net mvc里面的area是什么,点击这里查看 如果在nopcomm ...

  8. 小讲堂:在线编辑在Mobox文档管理软件中的意义

    今天我们来讨论一下,mobox文档管理软件中的在线编辑的这个功能,相信这个功能是用户在日常的文档维护中非常需要的. 文档管理软件的诸多功能中,在线编辑是一块很重要的功能点,因为在线编辑可以说是提高工作 ...

  9. 第11章 Java异常与异常处理

    1.Java异常简介 1.什么是异常异常出现的时候代码会无法正常运行下去,会产生各种问题2.捕捉异常的作用提早发现异常,方便查找问题,并给出解决方法3.Java中的异常1.Java中所有不正常的类都是 ...

  10. 第1章Java入门体验

    第1章Java入门体验 1.java简介和平台应用 Java是sun公司开发出来,现在属于ORACLE公司java分为几个部分:首先是最基础的Java SE部分,这部分是Java的基础知识,主要包括: ...