1. mysql :
1.1启动与停止mysql:
net start mysql80
net stop mysel80
1.2客户端连接:
2种,系统cmd与自带的cmd(直接打开)
mysql -u root-p
1.2.1 数据存储
RDBMS:关系型数据库:建立在关系模型基础上,由多张相互连接的二维表组成的库:
优点: 使用表来存储数据并且都使用sql语言,格式统一 ,便于维护
不通过表存储数据的是非关系型数据库
1.3 数据模型:
DBMS控制数据库操控数据(表):
客户端连接DBMS,使用sql语句来操控DBMS来创建数据库或在指定的数据库中创建表。
1.4 数据类型
数据类型 | 描述 | 示例 | 存储需求(字节数) |
---|---|---|---|
INT(INTEGER) | 整数类型,有符号范围为 - 2147483648 到 2147483647。 | 12345 | 4 |
BIGINT | 大整数类型,有符号范围很大。 | 9223372036854775807 | 8 |
SMALLINT | 小整数类型,有符号范围为 - 32768 到 32767。 | 5000 | 2 |
TINYINT | 微小整数类型,有符号范围为 - 128 到 127。 | 50 | 1 |
DECIMAL(p,s) | 定点数类型,p 表示总位数,s 表示小数位数。 | DECIMAL (5,2) 可存储 123.45 | 根据具体位数定,例如 DECIMAL (5,2) 需要 2 - 3 个字节用于存储小数部分,整数部分最多需要 2 个字节,总共大概需要 5 个字节左右 |
FLOAT | 单精度浮点数。 | 3.14159 | 4 |
DOUBLE | 双精度浮点数。 | 3.141592653589793 | 8 |
CHAR(n) | 定长字符串,n 表示字符长度。 | 'Hello'(若定义 CHAR (5) 会补空格) | n 个字节,n <= 255,例如 CHAR (10) 占用 10 个字节 |
VARCHAR(n) | 变长字符串,n 表示最大字符长度。 | 'World' | 实际长度加 1 - 2 个字节,n <= 65535 |
TEXT | 长文本类型。 | 一段较长的描述 | 根据实际长度定,一般来说,短的文本可能占用几个字节到几十个字节,较长的文本可能几百个字节甚至更多 |
---|---|---|---|
DATE | 日期类型,格式为 YYYY-MM-DD。 | '2024-09-07' | 3 |
TIME | 时间类型,格式为 HH:MM:SS。 | '12:30:45' | 3 |
DATETIME | 日期和时间类型,格式为 YYYY-MM-DD HH:MM:SS。 | '2024-09-07 12:30:45' | 8 |
ENUM | 枚举类型,只能从给定的值中选择一个。 | ENUM('red', 'green', 'blue') | 1 或 2 个字节,取决于枚举值的个数,最多 65535 个值需要 2 个字节 |
SET | 集合类型,可以从给定的值中选择多个。 | SET('a', 'b', 'c') | 1、2、3、4 或 8 个字节,取决于集合中值的个数 |
BOOLEAN | 布尔类型,存储 TRUE 或 FALSE。 | TRUE | 1 |
BLOB | 二进制大对象类型,用于存储大量二进制数据。 | 图片、文件等二进制数据 | 根据实际长度定 |
使用方法
用户名 USERNAME varchar(50)
性别 GENDER CHAR(1)
2.sql语法
2.1基本格式:
- 分号结尾
- 可读性:空格缩进
- 不区分大小写,关键字建议大写
- 单行注释--或者#注释内容 多行注释/* */
2.2 sql语句分类
DDL:数据定义语言,定义数据库对象:数据库,表,字段等
DML:数据操作语言,对数据表中的数据进行增删改查
DQL:数据查询语言,查询数据库中表的记录
DCL:数据控制语言,创建数据库用户,以及控制用户权限,比如增删改查的权限
DCL语句
查询用户: USE MYSQL; SELECT * FROM USER;
创建用户: CREATE USER '用户名'@'主机名' IDENTIFIED BY '密码';
修改用户密码: ALTER USER '用户名'@'主机名' IDENTIFIED WITH mysql_native_password BY '新密码';
删除用户:DROP USER '用户名'@'主机名';
案例练习:
-- 创建用户 itcast , 只能够在当前主机localhost访问, 密码123456;
create user 'itcast'@'localhost' identified by '123456';-- 创建用户 heima , 可以在任意主机访问该数据库, 密码123456 ;
create user 'heima'@'%' identified by '123456';-- 修改用户 heima 的访问密码为 1234 ;
alter user 'heima'@'%' identified with mysql_native_password by '1234';-- 删除itcast@localhost用户
drop user 'itcast'@'localhost';-- 查询权限
show grants for 'heima'@'%';-- 授予权限
grant all on itcast.* to 'heima'@'%';-- 撤销权限
revoke all on itcast.* from 'heima'@'%';
DDL语句
创建: 创建数据库([]可省略):CREATE DATABASE [IF NOT EXISTS] 数据库名 [DEFAULT CHARSET 字符集][COLIATE 排序规则]EX:create database test default charset utf8mb4;通常用这个字符格式,因为有的字符是四个字节,utf8只有3个字节表操作:创建表: CREATE TABLE 表名(字段1 字段1类型[COMMENT 字段1注释]字段2 字段2类型[COMMENT 字段2注释]字段3 字段3类型[COMMENT 字段3注释])[COMMENT 表的注释];EX: create table ttbb(-> id int comment '编号',-> name varchar(50) comment '姓名',-> age int comment '年龄',-> gender varchar(1) comment '性别'-> )comment '用户表';
查询:查询所有数据库: SHOW DATABASES;查询当前数据库: SELECT DATABASE();使用数据库(切换数据库): USE 数据库名查询当前数据库的所有表: SHOW TABLES;查询表结构: DESC 表名;查询 指定表 的 建表语句:SHOW CREATE TABLES 表名:
删除:
删除数据库:
DROP DATABASE IF EXISTS 数据库名
EX:drop database if exists test;
删除字段: ALTER TABLE 表名 DROP 字段;
删除表:DROP TABLE IF EXISTS 表名;
删除指定表并重新创建: TRUNCATE TABLE 表名;(清空数据,只留下了表)
修改:
添加字段: ALTER TABLE 表名 ADD 字段名 类型(长度) [COMMENT 注释] [约束];
修改字段名或者字段类型: ALTER TABLE 表名 CHANGE 旧字段名 新字段名 类型(长度)[COMMENT 注释] [约束];
修改表名 ALTER 表名 RENAME TO 新表名
DML语句
给指定字段添加数据: INSERT INTO 表名 (字段1,字段2····)VALUES(值1,值2····);
给全部字段添加数据:INSERT INTO 表名 VALUES(值1,值2····);
批量添加数据:INSERT INTO 表名 (字段1,字段2····)VALUES(值1,值2····),(值1,值2····),(值1,值2····)
INSERT INTO 表名 VALUES(值1,值2····),(值1,值2····),(值1,值2····);
UPDATE 表名 SET 字段名1=值1,字段名2=值2,····[WHERE 条件]
EX: UPDATE TTBB SET ID =1 WHERE NAME=233;
删除数据:DELETE FROM 表名 [WHERE 条件];
DQL语句
查询多个字段: SELET 字段1,字段2,···FROM 表名;
SELECT * FROM 表名;
设置别名:SELECT 字段1 [AS 别名],字段2 [AS 别名]···;
去除重复记录: SELECT DISTINCT 字段列表 FROM 表名;
查询指定字段: SELECT NMAE FROM TTBB;
查询所有字段: SELECT *(遵循开发规范) from emp;
不重复查询: SELECT DISTINCT ADDRESS '工作地址' FROM TTBB;(AS可省略);
条件查询:
查询年龄为10: SELECT * FROM TTBB WHERE AGE= 10;
查询年龄小于10:SELECT * FROM TTBB WHERE AGE <10;
查询没有填写身份证的人: SELECT * FROM TTBB WHERE IDCARD IS NULL;
查询有身份证的人: SELECT * FROM TTBB WHERE IDCARD I NOT NULL;
查询年龄不等于33的人;SELECT * FROM TTBB WHERE AGE !=33;(WHERE AGE <>33)
查询年龄在15-20:SELECT * FROM TTBB WHERE AGE <=20&&AGE>=15;SELECT * FROM TTBB WHERE AGE <=20 AND AGE>=15;SELECT * FROM TTBB WHERE AGE BEWTEEN 15 AND 20;(从小到大)
查询年龄为15和20:SELECT * FROM TTBB WHERE IN(15,20);
查询姓名为两个字的 SELECT * FROM TTBB WHERE NAME like '__';
查询idCARD最后为X的 SELECT * FROM TTBB WHERE IDCARD like '%X';
DQL-聚合函数:列计算统计人数 SELECT COUNT(ID/*)FROM EMP;#null不参与平均年龄 SELECT AVG(AGE) FROM TTBB;最大年龄 SELECT MAX(AGE) FROM TTBB;最小年龄 SELECT MIN(AGE) FROM TTBB;年龄之和 SELECT SUM(AGE) FROM TTBB WHERE ADRESS = "西安";
DQL分组查询
分组查询: SELECT 字段列表 FROM [WHERE 条件] GROUP BY 分组字段名 [HAVING 分组过滤后的条件]
根据性别分,统计男女数量: SELECT gender,COUT(*) FROM TTBB GROUP BY gender;
根据性别分组,统计男女平均年龄 SELECT gender,AVG(age) FROM TTBB GROUP BY gender;
查询年龄小于45的员工,并根据工作地址分组,获取员工数量大于等于3的工作地址:SELECT ADDRESS COUT(*) FROM ttbb WHERE AGE<=45 GROUP BY address HAVING COUT(*)>=3;
DQL排序查询
DQL-排序查询:SELECT 字段列表 FROM 表名 ORDER BY 字段1 排序方式,字段2,排序方式;
根据年龄对公司员工今昔升序排列: SELECT * FROM TTBB ORDER BY AGE ASC;
根据入职时间,降序排序 SELECT * FROM TTBB ORDER BY DATE DESC;
DQL-分页查询
SELECT 字段列表 FROM 表名 LIMIT 起始索引,查询记录数;
DQL执行顺序
3.权限说明
MYSQL中定义了很多权限,常用的只有几种
4.函数
-- 字符串函数
-- concat
select concat('Hello' , ' MySQL');-- lower
select lower('Hello');-- upper
select upper('Hello');-- lpad
select lpad('01', 5, '-');-- rpad
select rpad('01', 5, '-');-- trim
select trim(' Hello MySQL ');-- substring
select substring('Hello MySQL',1,5);-- 案例: 由于业务需求变更,企业员工的工号,统一为5位数,目前不足5位数的全部在前面补0。比如: 1号员工的工号应该为00001。
update emp set workno = lpad(workno, 5, '0');
数值函数:
-- ceil
select ceil(1.1);-- floor
select floor(1.9);-- mod
select mod(7,4);-- rand
select rand();-- round
select round(2.344,2);-- 案例: 通过数据库的函数,生成一个六位数的随机验证码。
select lpad(round(rand()*1000000 , 0), 6, '0');
日期函数
-- curdate()
select curdate();-- curtime()
select curtime();-- now()
select now();-- YEAR , MONTH , DAY
select YEAR(now());select MONTH(now());select DAY(now());-- date_add
select date_add(now(), INTERVAL 70 YEAR );-- datediff
select datediff('2021-10-01', '2021-12-01');-- 案例: 查询所有员工的入职天数,并根据入职天数倒序排序。
select name, datediff(curdate(), entrydate) as 'entrydays' from emp order by entrydays desc;
-- 流程控制函数
-- if
select if(false, 'Ok', 'Error');-- ifnull
select ifnull('Ok','Default');select ifnull('','Default');select ifnull(null,'Default');-- case when then else end
-- 需求: 查询emp表的员工姓名和工作地址 (北京/上海 ----> 一线城市 , 其他 ----> 二线城市)
selectname,( case workaddress when '北京' then '一线城市' when '上海' then '一线城市' else '二线城市' end ) as '工作地址'
from emp;-- 案例: 统计班级各个学员的成绩,展示的规则如下:
-- >= 85,展示优秀
-- >= 60,展示及格
-- 否则,展示不及格create table score(id int comment 'ID',name varchar(20) comment '姓名',math int comment '数学',english int comment '英语',chinese int comment '语文'
) comment '学员成绩表';
insert into score(id, name, math, english, chinese) VALUES (1, 'Tom', 67, 88, 95 ), (2, 'Rose' , 23, 66, 90),(3, 'Jack', 56, 98, 76);--
selectid,name,(case when math >= 85 then '优秀' when math >=60 then '及格' else '不及格' end ) '数学',(case when english >= 85 then '优秀' when english >=60 then '及格' else '不及格' end ) '英语',(case when chinese >= 85 then '优秀' when chinese >=60 then '及格' else '不及格' end ) '语文'
from score;
5.约束
约束:限制存储在表中的数据。
约束示例:
create table user(id int primary key auto_increment comment '主键',name varchar(10) not null unique comment '姓名',age int check ( age > 0 && age <= 120 ) comment '年龄',status char(1) default '1' comment '状态',gender char(1) comment '性别'
) comment '用户表';-- 插入数据
insert into user(name,age,status,gender) values ('Tom1',19,'1','男'),('Tom2',25,'0','男');
insert into user(name,age,status,gender) values ('Tom3',19,'1','男');insert into user(name,age,status,gender) values (null,19,'1','男');
insert into user(name,age,status,gender) values ('Tom3',19,'1','男');insert into user(name,age,status,gender) values ('Tom4',80,'1','男');
insert into user(name,age,status,gender) values ('Tom5',-1,'1','男');
insert into user(name,age,status,gender) values ('Tom5',121,'1','男');insert into user(name,age,gender) values ('Tom5',120,'男');约束 (外键)
--准备数据
create table dept(id int auto_increment comment 'ID' primary key,name varchar(50) not null comment '部门名称'
)comment '部门表';
INSERT INTO dept (id, name) VALUES (1, '研发部'), (2, '市场部'),(3, '财务部'), (4, '销售部'), (5, '总经办');create table emp(id int auto_increment comment 'ID' primary key,name varchar(50) not null comment '姓名',age int comment '年龄',job varchar(20) comment '职位',salary int comment '薪资',entrydate date comment '入职时间',managerid int comment '直属领导ID',dept_id int comment '部门ID'
)comment '员工表';INSERT INTO emp (id, name, age, job,salary, entrydate, managerid, dept_id) VALUES(1, '金庸', 66, '总裁',20000, '2000-01-01', null,5),(2, '张无忌', 20, '项目经理',12500, '2005-12-05', 1,1),(3, '杨逍', 33, '开发', 8400,'2000-11-03', 2,1),(4, '韦一笑', 48, '开发',11000, '2002-02-05', 2,1),(5, '常遇春', 43, '开发',10500, '2004-09-07', 3,1),(6, '小昭', 19, '程序员鼓励师',6600, '2004-10-12', 2,1);-- 添加外键
alter table emp add constraint fk_emp_dept_id foreign key (dept_id) references dept(id);-- 删除外键
alter table emp drop foreign key fk_emp_dept_id;-- 外键的删除和更新行为
alter table emp add constraint fk_emp_dept_id foreign key (dept_id) references dept(id) on update cascade on delete cascade ;alter table emp add constraint fk_emp_dept_id foreign key (dept_id) references dept(id) on update set null on delete set null ;
一张图看懂内外键
select * from emp , dept where emp.dept_id = dept.id; 去除多余的笛卡尔积
举例:
6.连接查询
内连接:相当于查询A、B交集部分数据
左外连接:查询左表所有数据,以及两张表交集部分数据
右外连接:查询右表所有数据,以及两张表交集部分数据
自连接:当前表与自身的连接查询,自连接必须使用表别名
左外连接:
右外连接:
自连接
union会去除重复,union all 则不会