一、一对一
一张表的一条记录一定只能与另外一张表的一条记录进行对应,反之亦然。
有时候,为了业务,或者避免一张表中数据量过大,过复杂,在开发中会进行一对一方式来设计表。
二、 一对多(1方建主表(id为主键字段), 多方建外键字段)
一个实体的某个数据与另外一个实体的多个数据有关联关系, 一对多的关系在设计的时候,需要设计表的外键。
2.1. 班级表和学生表设计
部门表和员工表设计
image.png
2.2.创建数据库表
constraint 约束
foreign key就是表与表之间的某种约定的关系,由于这种关系的存在,能够让表与表之间的数据,更加的完整,关连性更强。
foreign key语句的式例:FOREIGN KEY(Sno) REFERENCES Student(Sno)
注意:表的外键必须是另一张表的主键
//创建班级表create table class(id int primary key auto_increment,name varchar(20));//创建学生表create table student(id int primary key auto_increment,name varchar(20),sex varchar(20),class_id int,constraintforeign key(class_id) references class(id));//插入班级数据insert into class values(1,'ceshiban');insert into class values(2,'kaifa');//插入学生数据insert into student values(1,'zhangsan','nan',1);insert into student values(2,'lisi','nan',2);insert into student values(3,'jingjing','nan',2);//联查select * from student where class_id=(select id from class where id=2);
补一个外键的注意(默认是约束): 删除主键信息时,当该主键字段值在外键表中存在时,该记录是不能删除的。—要把外键表是的相关信息删除之后,才能删除。
子查询:嵌套在其他查询中的查询。
4.3、多对多( 3个表= 2个实体表 + 1个关系表 )
一个实体的数据对应另外一个实体的多个数据,另外实体的数据也同样对应当前实体的多个数据。
一个学生可以有多个老师,一个老师可以教多个学生
解决方案:创建一个中间表,专门用来维护多表之间的对应关系,通常是能够唯一标识出数据的字段(主键)
create table teacher(id int primary key,name varchar(100));create table student (id int primary key,name varchar(100));create table teacher_student(teacher_id int,student_id int,constraint foreign key(teacher_id) references teacher(id),constraint foreign key(student_id) references student(id));insert into teacher values(1,'梁老师');insert into teacher values(2,'李老师');insert into student values(1,”张三”);insert into student values(2,”李四”);insert into teacher_student values(1,1);insert into teacher_student values(1,2);insert into teacher_student values(2,1);insert into teacher_student values(2,2);//查询李老师所教的学生select id from teacher where name=’李老师’select student_id from teacher_student where teacher_id=idselect * from student where id in(select student_id from teacher_student where teacher_id =(select id from teacher where name='李老师'));//查询张三的所有老师select * from teacher where id in(select teacher_id from teacher_student where student_id=(select id from student where name='张三'));
五、 联表查询
分类:内连接、外连接、交叉连接
5.1. 初始定义表结构
create table customer(id int primary key auto_increment,name varchar(20),city varchar(20));create table orders(id int primary key auto_increment,good_name varchar(20),price float(8,2),customer_id int);insert into customer (name,city) values('李老师','东北');insert into customer (name,city) values('崔老师','山西');insert into customer (name,city) values('张老师','内蒙');insert into customer (name,city) values('闫老师','天津');insert into orders(good_name,price,customer_id) values('电脑',59,1);insert into orders(good_name,price,customer_id) values('笔记本',88,2);insert into orders(good_name,price,customer_id) values('吹风机',99,1);insert into orders(good_name,price,customer_id) values('香水',300,3);insert into orders(good_name,price,customer_id) values('牛奶',100,6);
5.2.交叉查询
交叉查询,又叫笛卡尔积查询,会将左表和右表的信息,做一个乘积将所有信息查询出来,会产生临时表,比较占用内存,生成的记录数=表1 X表2
5.3. 内连接查询
内连接,inner join on 查询两张表,设定条件,将两张表中对应的数据查询出来
不会产生笛卡尔积,不会产生临时表,性能高
5.4. 左外连接
左外连接 left join on 设定条件,将两张表对应的数据查询出来,同时将左表自己没有关联的数据也查询出来
注意:join前面是左,后面是右
5.5. 右外连接
右外连接 right join on 设定条件,将两张表对应的数据查询出来,同时将右表自己没有关联的所有数据查询出来
5.6. 联合查询
六、MySQL图形化工具navicat
6.1. Navicat简介
Navicat是一款桌面版MySQL数据库管理和开发工具。和微软SQLServer的管理器很像,简单、易学易用。Navicat使用图形化的用户界面,可以让用户使用和管理更为轻松,同时支持中文。
官网
2. 安装步骤:
下载破解版Navicat for MySQ中文破解版
链接:https://pan.baidu.com/s/1YK9U9opCUt1TthZvYxKBhg
提取码:mjw1
解压下载后的文件有两个.exe文件,点navicat111_mysql_cs_x64.exe 进行安装
安装完成之后点PatchNavicat.exe选择安装Navicat for MySQL目录下的navicat.exe
出现 下图破解成功
6.2 SQLyog
SQLyog中文版是一款专业的图形管理软件,SQLyog操作简单,功能强大,能够帮助用户轻松管理自己的MYSQL数据库,SQLyog中文版支持多种数据格式导出,可以快速帮助用户备份和恢复数据,还能够快速地运行SQL脚本文件,为用户的使用提供便捷。官网
3. MySQL Workbench
MySQL Workbench是一款专为MySQL设计的ER/数据库建模工具。它是著名的数据库设计工具DBDesigner4的继任者。可以用MySQL Workbench设计和创建新的数据库图示,建立数据库文档,以及进行复杂的MySQL 迁移。MySQL Workbench是下一代的可视化数据库设计、管理的工具,它同时有开源和商业化的两个版本。同时支持Windows和Linux系统。官网
4. MySQL GUI Tools
MySQL GUI Tools是一个可视化界面的MySQL数据库管理控制台,提供了四个非常好用的图形化应用程序,方便数据库管理和数据查询。MySQL GUI Tools可以极大地提高数据库管理、备份、迁移和查询效率,即使没有丰富的SQL语言基础的用户也可以应用自如。这款图形化管理工具算是最老牌的管理工具了。
官网
5. MySQL Connector/ODBC
MySQL Connector/ODBC 有时也可以叫做MyODBC,用户可以通过ODBC (Open Database Connectivity,开放数据库互联)数据库连接Mysql的服务器。比如说可以使用Windows或者Unix平台中的应用程序,如微软的 Access、Excel和Borland的Delphi去连接数据库服务器。MySQL Connector/ODBC 是MySQL官方提供的,系统安装了这个程序之后,就可以通过ODBC来访问MySQL,这样就可以实现SQLServer、Access和MySQL之间的数据转换,还可以支持ASP访问MySQL数据库。官网
6. phpMyAdmin
phpMyAdmin是最常用的MySQL维护工具,是一个用PHP开发的基于Web方式架构在网站主机上的MySQL管理工具,支持中文,管理数据库非常方便。是windows中PHP开发软件的标配。不足之处在于对大数据库的备份和恢复不太方便。官网
7. MySQLDumper
MySQLDumper使用PHP开发的MySQL数据库备份恢复程序,解决了使用PHP进行大数据库备份和恢复的问题,数百兆的数据库都可以方便的备份恢复,不用担心网速太慢导致中间中断的问题,非常方便易用。这个软件是德国人开发的,还没有中文语言包。官网
6.3. Navicat工具使用步骤
6.3.1. 链接,mysql,输入用户名,密码
6.3.2.新建库,鼠标点击右键
6.3.3.新建表
七、数据库备份与恢复
1. 使用图形界面工具:
2. 使用doc命令:
mysqldump –u用户名 –p密码 数据库名>生成的脚本文件路径
注意,不要打分号,不要登录mysql,直接在cmd下运行
注意,生成的脚本文件中不包含create database语句
mysqldump -uroot -proot host>C:\Users\Administrator\Deskt
op\mysql\1.sql
3. 导入SQL文件
导入文件
刷新即可,F5刷新
4.恢复
a)使用图形界面工具:
b)使用doc命令行:
i.不登录恢复
mysql -u用户名 -p密码 数据库<脚本文件路径
注意,不要打分号,不要登录mysql,直接在cmd下运行
ii.登录之后恢复
选择库 use 库名称
Source sql文件路径
八、数据库常用性能优化(了解)
数据库性能优化这块,我们考虑比较多的还是查询这块,互联网项目对数据查询非常频繁,对效率,性能要求比较高。
查询这块优化的话,主要就需要使用索引这种方式,所谓索引就是建立一种快速查找的方式,比如我们查字典,有一个ABCD的索引.
举个例子,如果我们创建一个表create table user(id integer ,name varchar(20),job varchar(20));如果我们数据库中有1000万条数据,当我查询select * from user where name=’张三’的时候,这种查询方式就类似于整个数据库的扫描,效率非常低。
我们可以给这个name设置一个索引create index n on user (name);这是设置一种普通(normal)索引,然后我们查询的时候,有了这个索引,效率就会大大提升,当然对于索引,它的方式有BTree类型和Hash类型,是两种管理数据库索引的方式,这个我没有深入研究。这个我们可以自己设置。默认是btree。
索引类型的话,有normal(普通类型)类型、unique(唯一类型)、fulltext全文索引、主键索引、非空索引、聚集索引。
①主键索引,primary key 在设置的时候,已经指定了,其实也是非空索引。
②非空索引是not null,设置这种方式的该字段下内容不能为空,
③聚集索引(联合索引),是在设置多个查询条件的时候使用。比如 创建一张表,有名字,有工作,我们想经常频繁的用到名字和工作它俩结合在一起来查询数据库中表的数据。这个时候,可以将名字和工作指定为聚集索引。create index m on user(name,job); 这样当我们指定select * from user where name=xxx and job=xxx的时候,就会按照索引方式来做。
这种优化方式就是索引优化,在使用索引优化方案的时候,我们需要注意避免在索引字段上使用条件函数等操作。
了解:
Show index form orders;查看索引
面试题:
为什么要创建索引呢(优点)?
这是因为,创建索引可以大大提高系统的性能。
①过创建唯一性索引,可以保证数据库表中每一行数据的唯一性。
②可以大大加快数据的检索速度,这也是创建索引的最主要的原因。
③可以加速表和表之间的连接,特别是在实现数据的参考完整性方面特别有意义。
④在使用分组和排序子句进行数据检索时,同样可以显著减少查询中分组和排序的时间。
⑤通过使用索引,可以在查询的过程中,使用优化隐藏器,提高系统的性能。
建立方向索引的不利因素(缺点)
也许会有人要问:增加索引有如此多的优点,为什么不对表中的每一个列创建一个索引呢?这种想法固然有其合理性,然而也有其片面性。虽然,索引有许多优点,但是,为表中的每一个列都增加索引,是非常不明智的。这是因为,增加索引也有许多不利的一个方面。
①创建索引和维护索引要耗费时间,这种时间随着数据量的增加而增加。
②索引需要占物理空间,除了数据表占数据空间之外,每一个索引还要占一定的物理空间,如果要建立聚簇索引,那么需要的空间就会更大。
③当对表中的数据进行增加、删除和修改的时候,索引也要动态的维护,这样就降低了数据的维护速度。
创建方向索引的准则
索引是建立在数据库表中的某些列的上面。因此,在创建索引的时候,应该仔细考虑在哪些列上可以创建索引,在哪些列上不能创建索引。
一般来说,应该在这些列上创建索引。
①在经常需要搜索的列上,可以加快搜索的速度;
②在作为主键的列上,强制该列的唯一性和组织表中数据的排列结构;
③在经常用在连接的列上,这些列主要是一些外键,可以加快连接的速度;
④在经常需要根据范围进行搜索的列上创建索引,因为索引已经排序,其指定的范围是连续的;
⑤ 在经常需要排序的列上创建索引,因为索引已经排序,这样查询可以利用索引的排序,加快排序查询时间;
⑥在经常使用在WHERE子句中的列上面创建索引,加快条件的判断速度。
同样,对于有些列不应该创建索引。一般来说,不应该创建索引的的这些列具有下列特点:
①对于那些在查询中很少使用或者参考的列不应该创建索引。这是因为,既然这些列很少使用到,因此有索引或者无索引,并不能提高查询速度。相反,由于增加了索引,反而降低了系统的维护速度和增大了空间需求。
②对于那些只有很少数据值的列也不应该增加索引。这是因为,由于这些列的取值很少,例如人事表的性别列,在查询的结果中,结果集的数据行占了表中数据行的很大比例,即需要在表中搜索的数据行的比例很大。增加索引,并不能明显加快检索速度。
③对于那些定义为text, image和bit数据类型的列不应该增加索引。这是因为,这些列的数据量要么相当大,要么取值很少。
④当修改性能远远大于检索性能时,不应该创建索引。这是因为,修改性能和检索性能是互相矛盾的。当增加索引时,会提高检索性能,但是会降低修改性能。当减少索引时,会提高修改性能,降低检索性能。因此,当修改性能远远大于检索性能时,不应该创建索引。
九、数据库性能检测方式(了解)
在设计SQL的时候,我们一般会使用explain检测sql,看是否使用到索引,避免出现整表搜索方式查询[filesort(不是以索引方式的检索,我们叫做filesort)](我在这张表中把gender设置成normal索引,name没有任何设置)
对比看的,对有索引的字段,在检测的时候,会显示是一个引用的key。
explain select*from tb_product where title=”;
还可以使用profiling方式检测数据库执行的方式,可以查询sql的运行时间。http://www.jb51.net/article/31870.htm
注释:查看profiling信息,show variables like ‘%profiling%’;
第一步:set profiling=1;(开启profiling)
第二步运行:select title from tb_product ;
第三步:查看运行时间show profiles;
Duration:持续时间,事件花费的时间总计(以毫秒为单位?)
十、数据库视图
10.1 简介
视图是从一个或几个基本表(或视图)导出的表。
它与基本表不同,是一个虚表。数据库只存放视图的定义,而不存放视图对应的数据,这些数据仍存放在原来的基本表中。
所以基本表中的数据发生变化,从视图中查询出的数据也就随之改变了。
从这个意义上讲,视图就像一个窗口,透过它可以看到数据库中自己感兴趣的数据及其变化。
视图只供查询,数据不可更改
10.2 视图的作用:
1、视图隐藏了底层的表结构,简化了数据访问操作,客户端不再需要知道底层表的结构及其之间的关系。
2、视图提供了一个统一访问数据的接口。(即可以允许用户通过视图访问数据的安全机制,而不授予用户直接访问底层表的权限)
3、从而加强了安全性,使用户只能看到视图所显示的数据。
4、视图还可以被嵌套,一个视图中可以嵌套另一个视图。
总结:使用视图,需要把它看着为一张表,建立步骤和建立一张实体表步骤相同,
视图查出来的数据只能进行查看,不能增删改。
隐藏了复杂的sql语句,只显示最简单的查询操作