MySQL基础
一、数据库基础
1、数据库概述
①概念:依照某种数据模型组织起来并存放在二级存储器(硬盘)中的数据集合。
②主流的数据库:关系型的有 MySQL
、SQLserver
、oracle
、DB2
,非关系型:HBase
、NoSQL
(mongoDB
、redis
、memache
)
2、概念模型
① 概念:是现实世界到机器世界的一个中间层侧,是数据库设计人员和用户之间交流的工具,通过它可以转换得到数据模型。
② 特点:简单清晰,易于理解,较强的语义表达能力。
③ 涉及到的基本概念:
实体(一本书,一个人)
属性(对实体的描述)
码:
超码:能够唯一确定的一个实体的一个或多个属性的集合。
候选码:能够确定一个实体的多个属性。
主码:能够唯一确定的一个实体的属性。
实体型和实体集:课程(课程号、课程名)就是一个实体型,所有课程组成一个实体集。
联系
一对一(
1:1
)一对多(
1:n
)多对多(
m:n
)
④ E-R模型和E-R图
- 用矩形表示实体,用椭圆表示属性,用菱形表示关系,用直线连接。
3、数据模型
① 数据模型的特点
能比较真实的模拟现实世界;
容易理解;
便于在计算机上实现;
② 数据模型的组成要素
数据结构(静态特性的描述)
数据操作(主要是查询和更新)
完整性约束条件
③ 常见的数据模型
层次模型
定义:用树型结构表示实体之间的联系的模型
特点:在一个层次模型中的限制条件是:有且仅有一个节点,无父节点,此节点为树的根;其他节点有且仅有一个父节点。
网状模型
定义:用网络结构表示实体类型及其实体之间联系的模型
特点:
允许一个以上的节点无父节点
一个节点可以有多于一个父节点
关系模型
定义:用二维表的形式表示实体和实体之间联系的数据模型
特点:
数据结构简单(二维表)
扎实的理论基础:
关系运算理论
关系模式设计理论
关系数据模型的三种约束完整性
实体完整性:实体的主键不能取空值。
参照完整性:是指参照关系中每个元素的外码要么为空(NULL),要么等于被参照关系中某个元素的主码。
用户定义完整性:指对关系中每个属性的取值作一个限制(或称为约束)的具体定义。比如 性别属性只能取”男“或”女“ ,再就是年龄的取值范围,可以取值0-130 ,但不能取负数,因为年龄不可能是负数。
二、MySQL基本知识
1.MySQL概述
(1)MySQL
是一个小型关系型数据库管理系统。
(2)特点:
图形化用户界面,使得系统管理和数据库管理跟家直观、简单。
丰富的编程接口工具
支持多用户、多线程
跨平台使用
2.MySQL的安装
(1) MySQL
为免费开源,可以在官网下载安装;Github
链接:https://github.com/mysql/mysql-server
(2) DBeaver
是 MySQL
的图形化管理软件,Github
链接:https://github.com/dbeaver/dbeaver
(3) 点击【连接】,选择 MySQL
(4) 输入连接名(可以自己取名字),输入服务器 IP
地址(本次直接用 localhost
即可),输入服务器端口号、用户名(root)和密码(可以为空)
3.远程访问数据库
(1) 服务器端需要授权:MySQL
查询编辑上输入:
grant all privileges on*.*to’用户名’@’%’ identified by’密码’ with grant option;
%
,是指对所有人,如果是针对某个人,可替换为对应的 IP
(2) 关闭防火墙
(3) Flush privileges
(刷新权限)
4.MySQL系统数据简介
(1) 四个系统数据库
Information schema
是信息数据库。保存MySQL
服务器维护的其他数据库的信息。MySQL
系统数据库,主要存储了一些存储MySQL
服务的系统信息表。Performance_schema
用于收集数据库服务器性能参数。Sys
系统数据库,可以了解系统的元数据信息。
(2) 常用的 MySQL
数据类型
int
整型,可以存储2
的31
次方到2
的31
次方之间的整数。占用4个字节。Float
浮点型,小数,在MySQL
里是4
个字节单精度。Char
字符型,存储制定长度的定长非统一编码型的数据。(固定长度)Varchar
字符型,指定最大长度。(可以小于)
(3) 数据库的基本操作
create database dbname;
(创建数据库)Drop database dbname;
(删除数据库)Create table name;
(创建表)Varchar(5)
长度为5个字符以内Primary key`(主键)
Not null`(不能为空)
Create database dbname default character set utf8 collate utf8_general_ci;
(创建一个字符集为utf8的数据库,否则输入汉字时,会变成问号)Create database test
:代表的是创建数据库 test;default character set utf8
:代表的是将默认编码格式设置为utf8格式;collate utf8_general_ci
:代表的是数据库校对规则;
三、数据库基本操作
1.数据库对象
(1)表:有行和列表示;
每列为一个字段。
每行为一条记录。
有一个唯一的主键,主键不能为空。
(2)外键:两个实体中的主键,在关系表中成为外键。
(3)索引(index
):根据指定的数据库表列建立起来的顺序;它提供了快速访问数据的途径。索引所指向的列中的数据不重复。
(4)视图(view
):是查询数据库产生的,从数据库去相应的数据进行呈现,视图内数据无法修改,在基表中修改后,视图表会自动修改。
(5)触发器(trigger
.扳机、开枪):设置一个触发的动作,对表自动进行增删改查。
(6)存储过程(store procedure
):存储在数据库的 SQL
程序。
2.表约束
主键约束(
primary key
)一个表通过一个列或多个列组合的数据来唯一标识表总的每一行,这一列或多个列的组合成为主键。
主键列具有唯一性;
一个表只有一个主键;
MySQL
通过主键建议唯一索引,加快对主键的查询速度;
主键约束两种写法
列级约束:直接在字段后定义
primary key
;sqlCreate table mikigo ( m_name primary key );
表级约束:先写完表,再定义表里的
primary key
;sqlCreate table mikigo ( m_name varchar(6), m_id varchar(11), Constraint pk_id primary key(m_id) );
外键约束(
foreign
)定义:建立和强调两个表之间的关系,即关系表的一个列与另一个表中的具有唯一性的列相关,这个列就是关系表中的外键。
唯一性约束(
unique
)保证在非主键的指定唯一性的列上不会出现重复的数据(在学生表中指定了学好为主键,身份证列作为非主键建立唯一性约束,则身份证号不能重复);
唯一性约束可以建立在多个非主键的列上,而且允许为空值(和主键约束的区别);
检查约束(
check
):在MySQL
上没有用;默认值约束(
default
):如果用户没有明确出某一列的值,将显示为默认值;空值约束(
null
):不为空时约束为not null
, 为空为null
,为空可以不写。
3.SQL结构化查询语句
SQL(structrued query language)查询语句包含四类:
数据定义语言(
DDL
,data definition language)数据操纵语言(
DML
,data manipulation language)数据控制语言(
DCL
,data control language)系统存储语言(System Stored procedure)
3.1.数据定义语言
(1) Create table
(建表)
Create table 表名(
sname varchar(3) not null,
Sid varchar(5) primary key
);
(2) Create index
(建索引)
(3) Alter table
(修改表)
(4) Drop table
(删表)
① Drop table 表名
(删除某个表)
(5) Drop index
(删索引)
(6) Insert into....select...
表示将一个表中的数据插入到另一个表中
Insert into student(sno,ssex,sname) Select sno,ssex,sname from student_1
(7) update 表名 set 列名=’更新值’ Where..
(表示更新某个字段数据)
update student
Set sname=’mikigo’
Where sno=401
(8) delete from 表名 Where..
(表示删除某行数据)(drop 是直接删表,delete是对表中的数据进行删除)
Delete from student
Where sno=101
(9)alter table修改表
修改表名:
Alter table 原表名 rename to 目标表名
sqlAlter table student rename to student_1
新增字段:
Alter table 表名 add 字段名 varchar(50) null
sqlAlter table student add pass_or_not varchar(50)
修改字段属性:
Alter table 表名 change 原字段名 新字段名 varchar(4)
sqlAlter table student change sno sno varchar(4) primary key
删除字段:
alter table 表名 drop column 字段名
sqlAlter table student drop column pass_or_not
3.2.数据操纵语言
(1) insert插入语句
Insert into student(sno, sname)(表名)
Values(001,mikigo)
表示向 student
表中插入一行数据。
Insert into student2(sno,sname)
Select student1 (s_no,s_name)
表示将 student1
中的内容插入到 student2
中。
(2) select查询
① Select * From student
(查询 student
表中所有列)
② Distinct
过滤重复行
Select distinct sno from score
(从成绩表中查询剔重后的学号)
(3) Where 子句,指定条件查询
① 范围运算符 between...and..
,not between....and...
((不)在什么之间)
Select title , price
From titles
Where price between 10 and 30
② 列表运算符 in
,not in
(表示在指定项中)
Select sname
From student
Where sno in (‘001’,’002’)
③ 空值判断符 is null
, is not null
(是否为空)
Select title , price
From titles
Where price is null
④ 逻辑运算符 and
, or
And
表示同时满足Or
表示满足一个条件即可
(4) 模糊匹配like , not like
① 匹配任意类型长度的字符用 %
,固定长度字符用下划线 _
Select sname ,sage
From student
Where sname like ‘%王%’ (‘王_’)
表示查询命中中带有“王”的姓名
② 指定一个字符、字符串或范围用[ ]、[^ ]
Select sname
From student
Where sname like ‘[b-k]%’
表示名字开头是 b-k
的姓名
(5) 集合函数(聚合函数)
① 平均值 avg
② 总和 sum
③ 最小值 min
④ 最大值 max
⑤ 计数 count
集合函数使用在select 后面
Select min(price) from titles
表示在表中,取价格的最小值,min(price) as 价格
(6) Group by 子句,分组
① Group by
子句中,不能使用集合函数
Select sname,ssex
From student
Group by ssex
表示已性别作为分组,统计显示姓名和性别
② select
中多个非集合项出现时,group by
里面也要有同样的非集合项
(7) Order by 排序:
对查询结果按照升序(asc
)或降序(desc
)排列。
Select sname,sage
From student
Where ssex=’男’
Order by sage desc
表示将 student
表中的男生,按照年龄降序排列,显示姓名和年龄
(8)having ...条件
Having
子句与 group by
使用表示增加某个条件。
select count(*)
From student
Group by ssex
Having age<15
(9)嵌套查询
①Where 表达式 (not)in (子查询)
select *
from score
where cno in(select cno
from course
where tno in(select tno from teacherwhere depart ='电子工程系'));
②比较运算符
Any
:where degree >any(81.85)
表示degree 大于81或85中的任意一个。All
:where degree >all(81.85)
表示degree 大于81或85中的每一个。Some
:同 any
③联接查询
内连接
sqlfrom student inner join score on student.sno=score.sno
或
sqlWhere student.sno=score.sno
外连接
左联接:(以左边表为基准,左边所有数据要出现,右边表无数据的,为空值)
sqlfrom course left join score on course.cno=score.cno
右联接: (以右边表为基准,右边所有数据要出现,左边表无数据的,为空值)
sqlfrom course right join score on course.cno=score.cno
3.3.数据控制语言(DCL
)
(1)grant 语句
Grant 权限1,权限2 on 表名 to uername
为某个用户授予某个权限
grant update on student to mikigo
(2)Revoke
语句
Revoke 权限1,权限2 on 表名 from uername
收回某个用户的某个权限
Revoke update on student from mikigo
3.4.View 视图
(1)视图是某个查询结果的虚表。试图对应的数据并不实际存在。
(2)语法:create view 视图名称 As Select 列名称 from 表名称 where 条件
Create view mikigo
As
Select *
From Student
Where ssex=’男’
(3)修改视图:drop view 视图名称。
3.5.procedure 存储过程
(1)存储过程的三个组成部分。
- 所有的输入参数以及传给调用者的输出参数;
- 被执行的正对数据库的操作语句,包括调用其它存储过程的语句;
- 返回给调用者的状态值,以指明调用是否成功;
(2)使用 DBeaver
创建存储过程
点击函数右键,选择新建函数,输入定义模式、参数名、数据类型;
点击完成,在
begin
和end
之间存储过程语句,点击保存,设置过程名;sqlBegin While i<30 do Insert into score values (floor(110+rand()+20),’5-245’,’99’); Set i=i+1; End while; End
调用的使用:
call
过程名(赋值);
3.6.trigger 触发器
(1)触发器是一种特殊类型的存储过程,主要通过事件进行触发而被执行。触发器用于MySQL约束、默认值和规则的完整新的检查。
(2)触发器类型:
Update
在更新时触发;Insert
在插入时触发;Delete
在删除操作时触发;After
在一个触发动作之后激活;
(3)语法:
Create trigger huang
After update on student for each row
Insert into student_1
Values (404,’明天’,’男’)
表示当对 student
表进行更新之后,将一组数据插入到 student_1
表中。
3.7.常见函数
(1)Left/right
函数
Select left (‘kdhoa’,3)
表示从左向右,截取3个字节
(2)Length
函数
Select length(‘ijgoado’)
表示括号内字符的长度
(3)Replace
函数
Select replace (‘ydk’,’k’,’a’)
表示将字符中的k 替换成a
(4)Substring
函数
Select substring (‘eohgdhd’,2,3)
表示从第2位开始取,往后取3位(ohg)
(5)日期函数
Now( )
:表示当前日期,精确到时分秒2019-10-29 19:31:20
;curdate( )
:表示当前时间,精确到日2019-10-29
Year( )
:表示日期年份2019
Month( )
:表示日期月份10
Day( )
:表示日期的日29
(6)Datediff
函数
- 表示函数返回两个日期之间的天数
Select datediff (‘time1’,’time2’)
计算逻辑是time1-time2