狂神说MySql笔记
Posted Code_BinBin
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了狂神说MySql笔记相关的知识,希望对你有一定的参考价值。
1、初识mysql
去年刚开始学java的时候,看的狂神老师的视频,现在整合一下之前做的笔记,发布出来供大家参考
javaEE:企业级java开发 Web
前端(页面:展示,数据)
后台(连接点:连接数据库JDBC,连接前端(控制试图跳转,和给前端传递数据)
数据库(存数据,Txt,Excel,word)
只会敲代码,学好数据库,基本混饭吃
操作系统,数据结构算法,一个不错的程序员
离散数学,数字电路,体系结构,编译原理+实战经验
1.1、为什么要学数据库
1.岗位需求
2.现在是大数据时代~,得数据中获得天下
3.被迫需求:存数据
4.数据库是所有软件体系最核心的存在 DBA
1.2、什么是数据库
数据库(DB,DataBase)
概念:数据仓库,软件,安装在操作系统(window,linux,mac)之上,可以存大量的数据
1.3、数据库分类
关系型数据库:SQL
- MySql ,Qracle,Sqlrver,DB2,SQLlite
- 通过表和表之间,行和列之间的关系
非关系型数据库 NOSQL Not Only
- Redis,MongDB
- 非关系型数据库,对象存储,通过对象自身的属性来决定
DBMS(数据库管理系统)
- 数据库的管理软件,科学有效的管理数据,维护和获取数据
- MySQL,数据库管理系统
1.4、MySQL介绍
关系型数据库管理系统
开源的数据库软件
体积小,速度快,成本低,招人成本低
1.4、连接数据库
命令连接
mysql -uroot -p密码 --连接数据库
updete mysql.user set authentication_string=password('密码')where user='root'and Host='localost';--修改用户名密码
flush privileges--刷新权限
-----------------------
所有语句";"结尾
show databases ---查看全部的数据库
user 数据库名字 ---查看数据库
show tables ----查看数据库表里的名字
describe 表名字----显示数据库里面表的信息
create database 数据库名字--创建一个数据库
exit--退出连接
#
--单行注释
/*
多行注释
*/
DDL 数据库定义语言
DML 数据库操作语言
DQL 数据库查询语言
DCL 数据库控制语言
2、操作数据库
2.1、操作数据库
1、创建数据库
CREATE DATABASE [IF NOT EXISTS] znb;
2、删除数据库
DROP DATABASE [IF EXISTS] znb;
3.使用数据库
USE school
4.查看数据库
SHOW DATABASES ;查看所有的数据库
2.2、数据库的列类型
数值
- tinyint 十分小的数据 一个字节
- smallint 较小的数据 , 两个字节
- mediumint 中等大小的数据 三个字节
- int 标准的整数 四个字节
- big 较大的数据 八个字节
- float 浮点数 四个字节
- double 浮点数 八个字节(精度问题)
- decimal 字符串形式的浮点数 金融计算的时候,一般用decimal
字符串
- char 字符串固定大小 0~255
- varchar 可变字符串 0~65535 常用的String
- tinytext 微形文本 2^8-1
- text 文本穿 2^16-1
时间日期
java,util.Date
- date yyyy-mm-dd,日期
- time hh:mm:ss 时间格式
- datetime yyyy-mm-dd hh:mm:ss 最常用的时间格式
- timestamp 时间戳 1970.1.1到现在的毫秒数 较为常用
- year 年份表示
null
- 没有数值,未知
- 不要用null运算,结果为null
2.3、数据库的字段属性(重点)
unsign
- 无符号的整数
- 声明了该列不能声明为负数
zerofill
- 0填充
- 不足的尾数用0来填充 int(3),5.········005
自增
- 在上一条的基础上加一
- 通常设置唯一的主键盘,必须是整数
- 可以自己设定数字
非空 NULL not null
- 假如设置为非空,不填数值就报错
默认
- 设置默认值
- sex 默认值为男,如果不指定该列的数值,都为默认
拓展
/*每一个表都要存在以下字段
id 主键
version 乐观锁
is_delete 伪删除
gmt_create 创建时间
gmt_uodate修改时间
*/
2.4、创建数据库表(重点)
CREATE TABLE IF NOT EXISTS `student`
(
`id`INT(4) NOT NULL AUTO_INCREMENT COMMENT '学号',
`pwd` VARCHAR(30) NOT NULL DEFAULT '***' COMMENT'密码',
`name` VARCHAR(30) NOT NULL DEFAULT '张三' COMMENT '姓名',
`sex` VARCHAR(50) NOT NULL DEFAULT '男' COMMENT '性别',
`birthday` VARCHAR (20) NOT NULL COMMENT '生日',
`address` VARCHAR(30) NOT NULL COMMENT'住址',
`emill` VARCHAR (30) NOT NULL COMMENT'邮箱',
PRIMARY KEY(`id`)
)ENGINE=INNODB DEFAULT CHARSET=utf8
格式
CREATE TABLE [IF NOT EXISTS]`表名`
(
`字段名` 类型 [属性] [索引] [注释],
`字段名` 类型 [属性] [索引] [注释],
`字段名` 类型 [属性] [索引] [注释],
)
`字段名` 类型 [属性] [索引] [注释]
)[表类型][字符集设置][注释]
常用命令
```sql
SHOW CREATE TABLE student--查看创建表的语句
SHOW CREATE DATABASE school--查看创建数据库的语句
DESC student--显示表的结构
2.5、数据表的类型
---数据库引擎---
/*
INNODB 默认使用
MYISAM 早些年使用
*/
INNODB | MYISAM | |
---|---|---|
事务支持 | 支持 | 不支持 |
数据行锁定 | 支持 | 不支持 |
外键约束 | 支持 | 不支持 |
全文索引 | 不支持 | 支持 |
表空间的大小 | 较大,为myisam的两倍 | 较小 |
常规使用操作
- MYISAM 节约空间,速度较快
- INNODB 安全性高,事务的处理,多表多用户操作
在物理空间存在的位置
所有的数据库文件都在data目录下
本质还是文件的存储!
Mysql引擎在物理引擎文件上面的区别
innoDB 在数据库表中只有一个*fm文件
2.6、修改和删除
修改
--修改表名
ALTER TABLE student RENAME AS student1
--修改约束
ALTER TABLE student MODIFY age1 FLOAT(10)
--修改表的属性名字
ALTER TABLE student CHANGE age1 age INT(10)
--删除表的字段
ALTER TABLE student DROP age
删除
DROP TABLE [IF EXISTS] teacher
所有的创建删除最好加上判断,避免出错
3、MySQL数据管理
3.1、外键
方法一:在创建表的时候增加约束
CREATE TABLE IF NOT EXISTS `student`
(
`id`INT(4) NOT NULL AUTO_INCREMENT COMMENT '学号',
`pwd` VARCHAR(30) NOT NULL DEFAULT '***' COMMENT'密码',
`name` VARCHAR(30) NOT NULL DEFAULT '张三' COMMENT '姓名',
`sex` VARCHAR(50) NOT NULL DEFAULT '男' COMMENT '性别',
`birthday` VARCHAR (20) NOT NULL COMMENT '生日',
`address` VARCHAR(30) NOT NULL COMMENT'住址',
`emill` VARCHAR (30) NOT NULL COMMENT'邮箱',
`gradeid` INT(4) NOT NULL COMMENT '学生的年级',
PRIMARY KEY(`id`),
KEY `FK_gradeid`(`gradeid`) ,
CONSTRAINT `FK_gradeid` FOREIGN KEY(`gradeid`) REFERENCES `grade`(`gradeid`)
)ENGINE=INNODB DEFAULT CHARSET=utf8
方式二:创建表成功后再去添加
ALTER TABLE student
ADD CONSTRAINT `FK_gradeid` FOREIGN KEY(`gradeid`) REFERENCES `grade`(`gradeid`);
3.2、DML语言
- Insert
- update
- delete
3.3添加
insert
--插入一个语句
INSERT INTO `student` (`name`) VALUES ('刘水龙')
--插入多个语句,用英文逗号隔开
INSERT INTO `student` (`name`,`sex`,`pwd`) VALUES
('李四','女','123154') ,('王五','女','1232154') ,
('刘三','女','123154') ,('赵四','女','12355154')
注意事项:
1.字段可以省略,但是后面的数值要一一对应
2.可以同时插入多个护具,VALUES后面的数值需要使用隔开即可
3.4修改
update 修改谁(条件) set 原来的数值=新数值
---带了条件
UPDATE `student` SET `name`='傻逼' WHERE id=3;
----不带条件会修改全部的数值
UPDATE `student` SET `name`='傻逼' ;
--多个属性用逗号隔开
UPDATE `student` SET `name`='傻逼',`pwd`='5201314' WHERE id=3;
操作符 | 含义 | 范围 | 结果 |
---|---|---|---|
= | 等于 | 1=2 | false |
<>或!= | 不等于 | 5<>6 | true |
> | |||
>= | |||
< | |||
<= | |||
BETWEEN …and… | 闭合区间 | ||
AND | 我和你 | ||
OR | 我或你 |
3.5、删除
delete
delete from 表名 where 条件
DELETE FROM `student` WHERE id= '4'
TRUNCATE命令
删除一个数据库表,表的结构和索引不变
delete 和 truncate的区别
-
相同:都可删数据库,不会删除表结构
-
不同:
truncate 重新设置自增列,计数器归零
truncate不会影事务
delete 问题,重启数据库现象
-
innoDB 自增列会重开始(存在内存当中的,断电即失)
-
MySAM 继续从上一个自增量开始(存在文件中的不会丢失)
4、DQL查询数据(重点)
4.1 DQL
(Data Query LANGUAGE :数据查询语言)
- 使用频率最高
select语法
4.2指定查询字段
--换一个别名打开,字段,表名都可以换
SELECT
`id` AS '学号',`name` AS '姓名',`9`AS '第九周',`10`AS '第十周',`11`AS '第十一周',`12`AS '第十二周',`13`AS '第十三周',
`14`AS '第十四周',`15`AS '第十五周',`16`AS '第十六周'
FROM `tykdk`
--查询全部的人
SELECT *FROM tykdk
去重 distinct
作用:去除select结果重复的数据
select distinct `id`from student
数据库的列(表达式)
SELECT VERSION()--查看系统版本
SELECT 100*3-1 AS 计算结果 ---用来计算
-----全员成绩加十分
SELECT `studentno+1`AS 加分后 FROM student
4.3、where条件语句
逻辑运算符号
运算符 | 语法 | 描述 |
---|---|---|
and && | a and b a&&b | |
or || | a or b a||b | |
Not ! | not a !a |
模糊查询
运算符 | 语法 | 描述 |
---|---|---|
IS NULL | a is null | |
IS NOT NULL | a is not null | |
BETWEEN | a between b and c | |
like | a like b | |
in | a in (a1,a2…) |
--在0和1之间
SELECT *FROM tykdk WHERE daka BETWEEN 0 AND 1
--最后一个字带龙,有几个字用几个“_”,不知道用%
SELECT *FROM tykdk WHERE `name` LIKE ('%龙')
--2018220111和2018220132两个
SELECT *FROM tykdk WHERE `id`IN('2018220111','2018220132')
4.4、联表查询
自连接
自己的表和自己的表连接,核心:拆成两个一模一样的表
父类
categoryid | categoryname |
---|---|
2 | 信息技术 |
3 | 软件开发 |
5 | 美术设计 |
子类
pid | categoryid | categoryname |
---|---|---|
3 | 4 | 数据库 |
2 | 8 | 办公信息 |
3 | 6 | web开发 |
5 | 7 | 美术设计 |
查询父类对应的子类
父类 | 子类 |
---|---|
信息技术 | 办公信息 |
软件开发 | 数据库 |
软件开发 | web开发 |
美术设计 | ps技术 |
SELECT a.`categoryname` AS 'father',b.`categoryname`AS'son'
FROM `test1`AS a,`test1`AS b
WHERE a.`categoryid`=b.`pid`
4.5、分页和排序
排序:
SELECT *FROM `student`
ORDER BY id DESC
----DESC降序,ASC排序----
分页
SELECT *FROM `tykdk`
ORDER BY `id` DESC
LIMIT 0,10
4.6、子查询
where(这个值是计算出来的)
本质:在where语句嵌套一个查询语句)
SELECT `id`,`name`,`pwd`
FROM `student`
WHERE id=(
SELECT `id` FROM `grade`
WHERE `pwd`='***'
)
4.7、分组和过滤
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-jMiW02m4-1621309051592)(C:\\Users\\ASUS\\AppData\\Roaming\\Typora\\typora-user-images\\image-20200429180334341.png)]
4.8、select小节
5、MySQL函数
5.1、常用函数
--数学
SELECT ABS(-55)
SELECT CEILING(22.995)
SELECT FLOOR(9.8)
SELECT RAND ()
SELECT SIGN(99)
--字串
SELECT CHAR_LENGTH('沃日你麻痹')
SELECT CONCAT('c','n','m')
SELECT INSERT ('我是你爸爸',1,2,'操你妈的逼')
SELECT LOWER('DSDDSADASF')
SELECT UPPER('sadasdasd')
SELECT INSTR ('zengnanbin','n')
SELECT REPLACE('你是一个大傻逼','傻逼','杂种')
SELECT REPLACE(`name`,'刘','牛') FROM `student`
WHERE `name` LIKE ('刘%')
---时间
SELECT CURDATE()
SELECT NOW()
SELECT LOCALTIME()
SELECT SYSDATE()
SELECT YEAR(NOW())
SELECT USER()
SELECT VERSION()
5.2、聚合函数
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-QRShGLiE-1621309051595)(C:\\Users\\ASUS\\AppData\\Roaming\\Typora\\typora-user-images\\image-20200429174708478.png)]
SELECT COUNT(`name`)FROM `tykdk`
SELECT SUM(`9`)AS '总和' FROM `tykdk`
SELECT AVG (`9`)AS '平均分'FROM `tykdk`
SELECT MAX(`9`)AS '最高分'FROM `tykdk`
SELECT MIN(`9`) AS '最低分'FROM `tykdk`
5.3、数据库级别的MD5加密
MD5不可逆,具体的MD5密码值是一样的
MD5破解网站的原理,背后有一个字典
UPDATE `testmd5` SET `pwd`='123456',`name`='张三' WHERE id=1
INSERT INTO `testmd5` (`pwd`,`name`) VALUES ('123457','李四'),('1234557','王五')
UPDATE `testmd5` SET `pwd`=MD5(pwd) WHERE id=1
INSERT INTO `testmd5` VALUES ('4',MD5('123456'),'xm')
6、事 务
要么都成功,要么都失败
事务原则:ACID原则 原子性,一致性,隔离性,持久性(脏读,欢幻)
参考博客:https://blog.csdn.net/dengjili/article/details/82468576
原子性(Atomicity)
要么都成功,要么都失败
一致性(Consistency)
事务前后数据要保持一致
隔离性(Isolation)
事务的隔离性是多个用户并发访问数据库时,数据库为每一个用户开启的事务,不能被其他事务的操作数据所干扰,多个并发事务之间要相互隔离。
持久性(Durability)
事务一旦提交就不可逆,被持久化到数据库中
隔离性问题:
执行事务
---mysql是默认开启事务自动提交的
SET autocmmit=0--关闭
SET autocommit=1--开启
---手动处理事务
SET autocommit =0--关闭自动提交
---事务开启
START TRANSACTION --标记一个事务的开始,从这个之后的sql都在一个事务内
INSERT XX
---提交:持久化(成功)
commit
--回滚--
ROLLBACK---回到之前的样子
--事务结束
SET autocommit=1---开启自动提交
--了解
SAVEPOINT 保存点名---设置一个事务保存点
ROLLBACK TO SAVEPOINT 保存点名--回滚到保存点
RELEASE SAVEPOINT 保存点名---撤销保存点
SET autocommit =0;--关闭自动提交
START TRANSACTION --开始事务
UPDATE account1 SET money=money-2000 WHERE `id` = 1
UPDATE account1 SET money=money+2000 WHERE `id` = 2
COMMIT;--成功
ROLLBACK;--回滚
SET autocommit=1;--开启自动提交
7、索引
7.1、索引的分类
在一个表中主键索引只可以有一个,唯一索引可以有多个
-
主键索引(PRIMARY KEY)
唯一标识,主键不可重复,只可有个
-
唯一索引(UNIQUE KEY)
避免重复的列出现,可以重复,多个列都可以标识唯一索引
-
常规索引(FullText)
默认的,可以用index,key关键字设置
-
全文索引
在特定的数据库引擎才有,mylsam
快速定位数据
--增加一个全文索引 ALTER TABLE school.student ADD FULLTEXT INDEX `studentName` (`studentName`) ----EXPLAIN 分析sql的执行情况 EXPLAIN SELECT *FROM student ---非全文索引 EXPLAIN SELLCT * FROM student WHERE MATCH(studentName)AGAINST('刘')
7.2、测试索引
---插入一千万条数据
DELIMITER $$
CREATE FUNCTION mock_data000()
RETURNS INT
BEGIN
DECLARE num INT DEFAULT 10000000;
DECLARE i INT DEFAULT 0;
WHILE i<num DO
INSERT INTO `app_user` (`name`,`phone`,`pwd`,`age`) VALUES
(CONCAT('用户',i),FLOOR(CONCAT('18',RAND()*(狂神说JavaMySQL最新教程通俗易懂--笔记