10记录数据库基础知识
数据库:DB(DataBase)
1.概念
顾名思义,就是数据仓库
作用:存储、管理数据
2.分类
1.关系型数据库 :SQL(Structured Query Language)
- MySQL、Oracle、SQLServer、SQLlite
- 表单形式
2.非关系型数据库:NoSQL(Not Only SQL)
- Redis、MongoDB
- 键值对形式
基本命令
所有的语句都要以分号结尾
show databases; --展示当前所有的数据库 use 数据库名; --打开指定的数据库 show tables; --查看所有的表 desc 表名; --显示表的信息 create database 数据库名; --创建一个数据库 exit; --退出数据库
操作数据库
1.创建数据库
create database 数据库名; --(前提)判断是否存在,以下同理
2.删除数据库
drop database 数据库名;
3.使用数据库
use 数据库名
4.查看数据库
show database;
数据库表
c创建一个学生表
CREATE TABLE IF NOT EXISTS `student`( `id` INT(4) NOT NULL AUTO_INCREMENT COMMENT '学号', `name` VARCHAR(30) NOT NULL DEFAULT '匿名' COMMENT '姓名', `pwd` VARCHAR(20) NOT NULL DEFAULT '123456' COMMENT '密码', `sex` VARCHAR(2) NOT NULL DEFAULT '女' COMMENT '性别', `birthday` DATETIME DEFAULT NULL COMMENT '出生日期', `address` VARCHAR(100) DEFAULT NULL COMMENT '家庭住址', `email` VARCHAR(50) DEFAULT NULL COMMENT '邮箱', PRIMARY KEY (`id`) )ENGINE=INNODB DEFAULT CHARSET=utf8
注意点
:
- 表名和字段尽量使用``括起来
- AUTO_INCREMENT 代表自增
- 所有的语句后面加逗号,最后一个不加
- 字符串使用单引号括起来
- 主键的声明一般放在最后,便于查看
- 不设置字符集编码的话,会使用MySQL默认的字符集编码Latin1,不支持中文,可以在my.ini里修改
DML语言
```Data Manipulation Luaguge`:数据操作语言``
1.添加insert
-- 普通用法 INSERT INTO `student`(`name`) VALUES ('zsr'); -- 插入多条数据 INSERT INTO `student`(`name`,`pwd`,`sex`) VALUES ('zsr','200024','男'),('gcc','000421','女'); -- 省略字段 INSERT INTO `student` VALUES (5,'Bareth','123456','男','2000-02-04','武汉','1412@qq.com',1);
语法
INSERT INTO 表名([字段1,字段2..])VALUES('值1','值2'..),[('值1','值2'..)..];
注意:
- 字段和字段之间使用英文逗号隔开
- 字段是可以省略的,但是值必须完整且一一对应
- 可以同时插入多条数据,VALUES后面的值需要使用逗号隔开
2.修改update
-- 修改学员名字,指定条件 UPDATE `student` SET `name`='zsr204' WHERE id=1; -- 不指定条件的情况,会改动所有表 UPDATE `student` SET `name`='zsr204'; -- 修改多个属性 UPDATE `student` SET `name`='zsr',`address`='湖北' WHERE id=1; -- 通过多个条件定位数据 UPDATE `student` SET `name`='zsr204' WHERE `name`='zsr' AND `pwd`='200024';
语法
UPDATE 表名 SET 字段1=值1,[字段2=值2...] WHERE 条件[];
3. 删除 delete
-- 删除数据(避免这样写,会全部删除) DELETE FROM `student`; -- 删除指定数据 DELETE FROM `student` WHERE id=1;
语法
delete from 表名 [where 条件]
DQL查询数据
```Data QueryLanguage` 数据查询语言``
SELECT [ALL | DISTINCT] {* | table.* | [table.field1[as alias1][,table.field2[as alias2]][,...]]} FROM table_name [as table_alias] [left | right | inner join table_name2] -- 联合查询 [WHERE ...] -- 指定结果需满足的条件 [GROUP BY ...] -- 指定结果按照哪几个字段来分组 [HAVING] -- 过滤分组的记录必须满足的次要条件 [ORDER BY ...] -- 指定查询记录按一个或多个条件排序 [LIMIT {[offset,]row_count | row_countOFFSET offset}]; -- 指定查询的记录从哪条至哪条
- 查询数据库数据 , 如SELECT语句
- 简单的单表查询或多表的复杂查询和嵌套查询
- 是数据库语言中最核心,最重要的语句
- 使用频率最高的语句
前提配置
-- 创建学校数据库 CREATE DATABASE IF NOT EXISTS `school`; -- 用school数据库 USE `school`; -- 创建年级表grade表 CREATE TABLE `grade`( `GradeID` INT(11) NOT NULL AUTO_INCREMENT COMMENT '年级编号', `GradeName` VARCHAR(50) NOT NULL COMMENT '年纪名称', PRIMARY KEY (`GradeID`) )ENGINE=INNODB AUTO_INCREMENT=6 DEFAULT CHARSET=utf8; -- 给grade表插入数据 INSERT INTO `grade`(`GradeID`,`GradeName`) VALUES (1,'大一'),(2,'大二'),(3,'大三'),(4,'大四'); -- 创建成绩result表 CREATE TABLE `result`( `StudentNo` INT(4) NOT NULL COMMENT '学号', `SubjectNo` INT(4) NOT NULL COMMENT '考试编号', `ExamDate` DATETIME NOT NULL COMMENT '考试日期', `StudentResult` INT(4) NOT NULL COMMENT '考试成绩', KEY `SubjectNo` (`SubjectNo`) )ENGINE=INNODB DEFAULT CHARSET=utf8; -- 给result表插入数据 INSERT INTO `result`(`StudentNo`,`SubjectNo`,`ExamDate`,`StudentResult`) VALUES (1000,1,'2019-10-21 16:00:00',97),(1001,1,'2019-10-21 16:00:00',96), (1000,2,'2019-10-21 16:00:00',87),(1001,3,'2019-10-21 16:00:00',98); -- 创建学生表student CREATE TABLE `student`( `StudentNo` INT(4) NOT NULL COMMENT '学号', `LoginPwd` VARCHAR(20) DEFAULT NULL, `StudentName` VARCHAR(20) DEFAULT NULL COMMENT '学生姓名', `Sex` TINYINT(1) DEFAULT NULL COMMENT '性别,取值0或1', `GradeID` INT(11) DEFAULT NULL COMMENT '年级编号', `Phone` VARCHAR(50) NOT NULL COMMENT '联系电话,允许为空,即可选输入', `Adress` VARCHAR(255) NOT NULL COMMENT '地址,允许为空,即可选输入', `BornDate` DATETIME DEFAULT NULL COMMENT '出生时间', `Email` VARCHAR(50) NOT NULL COMMENT '邮箱账号,允许为空,即可选输入', `IdentityCard` VARCHAR(18) DEFAULT NULL COMMENT '身份证号', PRIMARY KEY (`StudentNo`), UNIQUE KEY `IdentityCard` (`IdentityCard`), KEY `Email` (`Email`) )ENGINE=MYISAM DEFAULT CHARSET=utf8; -- 给学生表插入数据 INSERT INTO `student`(`StudentNo`,`LoginPwd`,`StudentName`,`Sex`,`GradeID`,`Phone`,`Adress`,`BornDate`,`Email`,`IdentityCard`) VALUES (1000,'1241','dsaf',1,2,'24357','unknow','2000-09-16 00:00:00','1231@qq.com','809809'), (1001,'1321','dfdj',0,2,'89900','unknow','2000-10-16 00:00:00','5971@qq.com','908697'); -- 创建科目表 CREATE TABLE `subject`( `SubjectNo` INT(11) NOT NULL AUTO_INCREMENT COMMENT '课程编号', `SubjectName` VARCHAR(50) DEFAULT NULL COMMENT '课程名称', `ClassHour` INT(4) DEFAULT NULL COMMENT '学时', `GradeID` INT(4) DEFAULT NULL COMMENT '年级编号', PRIMARY KEY (`SubjectNo`) )ENGINE=INNODB AUTO_INCREMENT=18 DEFAULT CHARSET=utf8; -- 给科目表subject插入数据 INSERT INTO `subject`(`SubjectNo`,`SubjectName`,`ClassHour`,`GradeID`) VALUES(1,'高数','96',2),(2,'大物','112',2),(3,'程序设计',64,3); SELECT 字段 FROM 表;
基础查询
语法:
SELECT 查询列表 FROM 表名;
- 查询列表可以是:表中的(一个或多个)字段,常量,变量,表达式,函数
- 查询结果是一个虚拟的表格
-- 查询全部学生 SELECT * FROM student; -- 查询指定的字段 SELECT `LoginPwd`,`StudentName` FROM student; -- 别名 AS(可以给字段起别名,也可以给表起别名) SELECT `StudentNo` AS 学号,`StudentName` AS 学生姓名 FROM student AS 学生表; -- 函数 CONCAT(str1,str2,...) SELECT CONCAT('姓名',`StudentName`) AS 新名字 FROM student; -- 查询系统版本(函数) SELECT VERSION(); -- 用来计算(计算表达式) SELECT 100*53-90 AS 计算结果; -- 查询自增步长(变量) SELECT @@auto_increment_increment; -- 查询有哪写同学参加了考试,重复数据要去重 SELECT DISTINCT `StudentNo` FROM result;
条件查询
where 条件字句:检索数据中符合条件的值
语法:
select 查询列表 from 表名 where 筛选条件;
-- 查询考试成绩在95~100之间的 SELECT `StudentNo`,`StudentResult` FROM result WHERE `StudentResult`>=95 AND `StudentResult`<=100; -- && SELECT `StudentNo`,`StudentResult` FROM result WHERE `StudentResult`>=95 && `StudentResult`<=100; -- BETWEEN AND SELECT `StudentNo`,`StudentResult` FROM result WHERE `StudentResult`BETWEEN 95 AND 100; -- 查询除了1000号以外的学生 SELECT `StudentNo`,`StudentResult` FROM result WHERE `StudentNo`!=1000; -- NOT SELECT `StudentNo`,`StudentResult` FROM result WHERE NOT `StudentNo`=1000; -- 查询名字含d的同学 SELECT `StudentNo`,`StudentName` FROM student WHERE `StudentName` LIKE '%d%'; -- 查询名字倒数第二个为d的同学 SELECT `StudentNo`,`StudentName` FROM student WHERE `StudentName` LIKE '%d_'; -- 查询1000,1001学员 SELECT `StudentNo`,`StudentName` FROM student WHERE `StudentNo` IN (1000,1001);
分组查询
语法:
select 分组函数,分组后的字段 from 表 【where 筛选条件】 group by 分组的字段 【having 分组后的筛选】 【order by 排序列表】
区别:
使用关键字 | 筛选的表 | 位置 | |
---|---|---|---|
分组前筛选 | where | 原始表 | group by的前面 |
分组后筛选 | having | 分组后的结果 | group by 的后面 |
-- 查询不同科目的平均分、最高分、最低分且平均分大于90 -- 核心:根据不同的课程进行分组 SELECT SubjectName,AVG(StudentResult),MAX(`StudentResult`),MIN(`StudentResult`) FROM result r INNER JOIN `subject` s on r.SubjectNo=s.SubjectNo GROUP BY r.SubjectNo HAVING AVG(StudentResult)>90;
连接查询
目前记录左连接、右连接、内连接
-- 查询学员所属的年级(学号,学生姓名,年级名称) SELECT `StudentNo`,`StudentName`,`GradeName` FROM student s INNER JOIN grade g ON s.GradeID=g.GradeID; -- 查询科目所属的年级 SELECT `SubjectName`,`GradeName` FROM `subject` s INNER JOIN `grade` g ON s.GradeID=g.GradeID; -- 查询列参加程序设计考试的同学信息(学号,姓名,科目名,分数) SELECT s.`StudentNo`,`StudentName`,`SubjectName`,`StudentResult` FROM student s INNER JOIN result r on s.StudentNo=r.StudentNo INNER JOIN `subject` sub on r.SubjectNo=sub.SubjectNo where SubjectName='课程设计';
排序与分页
排序
语法
select 查询列表 from 表 where 筛选条件 order by 排序列表 asc/desc --说明desc倒序,默认升序
分页
语法
select 查询列表 from 表 limit offset,pagesize;
- offset代表的是起始的条目索引,默认从0开始
- size代表的是显示的条目数
-- 第一页 limit 0 5 -- 第二页 limit 5,5 -- 第三页 limit 10,5 -- 第n页 limit (n-1)*pagesize,pagesize -- pagesize:当前页面大小 -- (n-1)*pagesize:起始值 -- n:当前页面 -- 数据总数/页面大小=总页面数 -- limit n 表示从0到n的页面
子查询
本质:在 where
子句中嵌套一个子查询语句
-- 查询‘课程设计’的所有考试结果(学号,科目编号,成绩)降序排列 -- 方式一:使用连接查询 SELECT `StudentNo`,r.`SubjectNo`,`StudentResult` FROM result r INNER JOIN `subject` s on r.StudentNo=s.SubjectNo WHERE SubjectName='课程设计' ORDER BY StudentResult DESC; -- 方式二:使用子查询(由里到外) SELECT StudentNo,SubjectNo,StudentResult from result WHERE SubjectNo=( SELECT SubjectNo FROM `subject` WHERE SubjectName='课程设计' )
MySQL函数
1. 常用函数
-- 数学运算 SELECT ABS(-8); -- 绝对值 SELECT CEIL(5.1); -- 向上取整 SELECT CEILING(5.1); -- 向上取整 SELECT RAND(); -- 返回0~1之间的一个随机数 SELECT SIGN(-10); -- 返回一个数的符号;0返回0;正数返回1;负数返回-1 -- 字符串函数 SELECT CHAR_LENGTH('我喜欢你'); -- 字符串长度 SELECT CONCAT('我','喜欢','你'); -- 拼接字符串 SELECT INSERT('我喜欢',1,1,'超级') -- INSERT(str,pos,len,newstr) 从str的pos位置开始替换为长度为len的newstr SELECT UPPER('zsr'); -- 转大写 SELECT LOWER('ZSR'); -- 转小写 SELECT INSTR('zsrs','s'); -- 返回第一次出现字串索引的位置 SELECT REPLACE('加油就能胜利','加油','坚持'); -- 替换出现的指定字符串 SELECT SUBSTR('坚持就是胜利',3,6); -- 返回指定的字符串(源字符串,截取位置,截取长度) SELECT REVERSE('rsz'); -- 反转字符串 -- 时间日期函数 SELECT CURRENT_DATE(); -- 获取当前日期 SELECT CURDATE(); -- 获取当前日期 SELECT now(); -- 获取当前时间 SELECT LOCALTIME(); -- 本地时间 SELECT SYSDATE(); -- 系统时间 SELECT YEAR(NOW()); SELECT MONTH(NOW()); SELECT DAY(NOW()); SELECT HOUR(NOW()); SELECT MINUTE(NOW()); SELECT SECOND(NOW()); -- 系统信息 SELECT SYSTEM_USER(); SELECT USER(); SELECT VERSION();
2. 聚合函数
函数 | 描述 |
---|---|
max | 最大值 |
min | 最小值 |
sum | 和 |
avg | 平均值 |
count | 计算个数 |
SELECT COUNT(StudentName) FROM student; SELECT COUNT(*) FROM student; SELECT COUNT(1) FROM student; SELECT SUM(`StudentResult`) FROM result; SELECT AVG(`StudentResult`) FROM result; SELECT MAX(`StudentResult`) FROM result; SELECT MIN(`StudentResult`) FROM result;
事务
要么都成功,要么都失败
例子:银行转账 张三给李四转1000块钱
事务四大特性
原子性、一致性、隔离性、永久性
未完待续...
本文来自博客园,作者:__username,转载请注明原文链接:https://www.cnblogs.com/code3/p/16949796.html
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步