https://blog.csdn.net/weixin_44051608/article/details/85163823
一、启动MySQL
1、 win+R或者CMD中输入“services.msc”打开服务,在里面找到MYSQL服务进行控制
data:image/s3,"s3://crabby-images/e2c39/e2c392f90733591d7a7ac9b310aa6b4b777ad437" alt=""
2、cmd下我们输入 net stop mysql80 来禁用MYSQL服务
data:image/s3,"s3://crabby-images/1cff1/1cff172c66259d0046e36d73ee356001b9cccad4" alt=""
3、cmd下我们输入 net start mysql80 来启用MYSQL服务
data:image/s3,"s3://crabby-images/d2ad3/d2ad355d14fc6981a02c43411e9f2d2018569603" alt=""
二、连接MySQL服务器
- 连接本地MySQL
mysql -uroot -p
data:image/s3,"s3://crabby-images/d2705/d270513ae6b4020cb894d851bb686dcb2fb86bf9" alt=""
2、指令集
连接好后我们输入 \h 来查看一下命令集:
data:image/s3,"s3://crabby-images/27ddc/27ddc8b1ea6aeb241246354db2734f398bb072fb" alt=""
3、退出:
\q
exit
quit
data:image/s3,"s3://crabby-images/6d945/6d9459b5fec6432f795003d0e02de4a3f527aee2" alt=""
data:image/s3,"s3://crabby-images/5cf6d/5cf6d3ddd3ecc1c84fd4d2b5c28ee39bab70282c" alt=""
4、连接远程MySQL
mysql -h127.0.0.1 -uroot -p
data:image/s3,"s3://crabby-images/b2e60/b2e60925dd9c33d2ff79422e979294eb417cd2af" alt=""
或者使用:
mysql --host=127.0.0.1 --user=root --password
data:image/s3,"s3://crabby-images/70fb5/70fb5cc642dbb5191892d12d0b480ecb0953c0e1" alt=""
- 查看mysql端口
show global variables like 'port';
三、MySQL目录结构
1、安装目录
data:image/s3,"s3://crabby-images/3f449/3f449ad2f263a511b2850ae86cc6769e697bfa26" alt=""
2、数据目录
data:image/s3,"s3://crabby-images/9bc96/9bc96de62bae5921fda6a1b2d660fecda58fce30" alt=""
data:image/s3,"s3://crabby-images/e9ad9/e9ad941cbbd7ea4dc916ba5b789962bc3e57e114" alt=""
数据库:文件夹
表:文件夹中的文件
数据记录:文件内存储的内容
四、SQL通用语法
1、SQL可以单行或多行书写,以分号结尾。遇到分号之前随意换行
data:image/s3,"s3://crabby-images/4961f/4961f54b8b2a784c8ef70f8c5cc5a4f67f6903ca" alt=""
2、使用空格或者Tab提高可读性
3、不区分大小写,但关键字推荐用大写
4、单行注释 :① -- (两个横杠一个空格)② # (mysql特有)
5、多行注释:/* 。。。。 */
五、MySQL数据类型
1、数值类型
data:image/s3,"s3://crabby-images/c9961/c99616201b807249cac89e0899720842889758e2" alt=""
double(5,2) 表示总共5位,小数点后2位;
2、日期和时间类型
data:image/s3,"s3://crabby-images/14b8b/14b8b14e34b2ccce05a035ad2906ed4dc18567f9" alt=""
如果使用TIMESTAMP类型,则如果不赋值或者赋值为NULL,则默认保存系统当前时间。
3、字符串类型
data:image/s3,"s3://crabby-images/51411/514117d0151ce7e2c13e1ddc895fb31638cfa47c" alt=""
varchar(20) 表示最大20个字符
六、SQL分类
1 DDL :用来定义数据库对象:数据库、表、列等;关键字:create drop alter
2 DML:用来对数据库表中的数据进行增删改;关键字:insert delete update
3 DQL:用来查询数据库表中的记录;关键字:select where
4 DCL:定于数据库的访问权限和安全级别及创建用户 关键字:GRANT REVOKE
data:image/s3,"s3://crabby-images/c35d8/c35d8f4514990bc19b0c5df3b8b3d57c18ab00e4" alt=""
七、DDL操作:数据库
1、创建
①、创建数据库 create database 数据库名;
create database db1;
data:image/s3,"s3://crabby-images/c245a/c245a2647293fe8a4bd758623819a7027cb03a2a" alt=""
②、防止重复创建 create database if not exists 数据库名;
create database if not exists db1;
data:image/s3,"s3://crabby-images/cdbb8/cdbb84ce1b4ac254d647e38e24e2836cb6a95a8f" alt=""
③、指定字符集创建 create database 数据库名 character set 字符集名;
create database db3 character set gbk;
data:image/s3,"s3://crabby-images/9ba9e/9ba9e0bc43a0a8bd2e4f0cb8cf02a6832c718381" alt=""
④、判断存在否并指定字符集:create database if not exists 数据库名 character set 字符集名;
create database if not exists db4 character set gbk;
data:image/s3,"s3://crabby-images/fda4e/fda4e5a610dc6b659ffb0ee307146cf2d7d71b60" alt=""
2、查询
①、show databases; 显示所有数据库
show databases;
data:image/s3,"s3://crabby-images/44723/4472304b5b698ed478f4b2ed2670243203fb01a2" alt=""
数据库对应文件夹:
data:image/s3,"s3://crabby-images/2308d/2308d4b8ce9f1c1cb634197a796434248f57d150" alt=""
其中information_schema数据库是特殊视图,并没有对应的物理文件。
mysql对应的是核心数据库
performance_schema对应的是性能数据库
以上数据库不要乱动。
②、查询创建某数据库时使用的语法(主要为了查看字符集)
show create database 数据库名;
show create database mysql;
data:image/s3,"s3://crabby-images/1f738/1f73865fd77b7318430687d82b9ce9e097999800" alt=""
3、修改
①、修改字符集:alter database 数据库名 character set 字符集名;
alter database db4 character set utf8;
data:image/s3,"s3://crabby-images/3e1e4/3e1e4a28c740eb9abc5abdb36ea6235a555a9c37" alt=""
4、删除
①、删除数据库:drop database 数据库名;
drop database db3;
data:image/s3,"s3://crabby-images/f3943/f394320437007715bb2c998866cd756064202556" alt=""
②、先检查有没有再删除:drop database if exists 数据库名;
drop database if exists db3;
data:image/s3,"s3://crabby-images/05c59/05c59d3bcdf577dab5630778040dcf31f1153f2e" alt=""
5、使用
① 查询当前正在使用的数据库名称:select database();
select database();
data:image/s3,"s3://crabby-images/5e872/5e87234f2437740dd849cb75a4ba64e4f16e119b" alt=""
②、使用数据库: use 数据库名;
use db1;
data:image/s3,"s3://crabby-images/7248d/7248dea512bf0810d421138a0a1bce16f2cca6df" alt=""
八、DDL操作:表
1、创建
①、创建表:create table 表名(列名1 数据类型1,列名2 数据类型2,...,列名n 数据类型n);
create table student(id int,name varchar(32),age int,score double(4,1),brithday date,insert_time timestamp);
data:image/s3,"s3://crabby-images/7228b/7228bae99da0ff6a472664093f7e8b18bf938378" alt=""
完成后查一下:
data:image/s3,"s3://crabby-images/5226d/5226de289dc0982b7b25ef15ba4a630e3983a5be" alt=""
2、查询
①、查询表集合: show tables;
show tables;
data:image/s3,"s3://crabby-images/7e9c3/7e9c328c39574143035bbddfd7d4cd4bae7094cc" alt=""
②、查询表结构: desc 表名;
desc student;
data:image/s3,"s3://crabby-images/3ab22/3ab22aaf08b2e2182053923d13bf76b8cc034372" alt=""
3、修改
①、修改表名
alter table 表名 rename to 新表名;
alter table student rename to students;
data:image/s3,"s3://crabby-images/2cebe/2cebe699b95a7abdb7c8ad636caf1a45dad07940" alt=""
②、修改表的字符集
alter table 表名 character set 字符集名;
alter table students character set utf8;
data:image/s3,"s3://crabby-images/f5f7b/f5f7beb6302507a73176c55cec5105e259e4ca36" alt=""
③、添加一列
alter table 表名 add 列名 数据类型;
alter table students add sex varchar(10);
data:image/s3,"s3://crabby-images/06a1a/06a1abb8aacb1a7e1ca69825a571f3d7f682725e" alt=""
④、修改一列
alter table 表名 change 列名 新列名 新数据类型;
alter table students change sex gender varchar(20);
data:image/s3,"s3://crabby-images/33fd2/33fd2af27740af0e909fa7cee19ac151fa31a2cf" alt=""
⑤、只修改列的类型
alter table 表名 modify 列名 新数据类型;
alter table students modify gender varchar(10);
data:image/s3,"s3://crabby-images/01542/0154280e7f59441242818128ad3658705bed2f99" alt=""
⑥、删除列
alter table 表名 dorp 列名;
alter table students drop gender;
data:image/s3,"s3://crabby-images/8f7e9/8f7e92f7f284d53577205157098b6f5c54ee7424" alt=""
4、删除
drop table 表名;
drop table students;
drop table if exists 表名;
drop table if exists students;
九、一个图形化软件mysql workbench
使用图形化软件来更加直观方便的操作数据库,现在MySQL下载会自带
连接数据库后如图:
data:image/s3,"s3://crabby-images/28c89/28c89cf1493eef15f2bacae638fec4b2466e80f5" alt=""
数据库在哪?
data:image/s3,"s3://crabby-images/dca6f/dca6f2c7a046df46f731218c8defc7ea7844ad4c" alt=""
如何直观的看到表格?
data:image/s3,"s3://crabby-images/d3744/d37446737f1aed269ac00d613a8e809906588a9a" alt=""
data:image/s3,"s3://crabby-images/b111c/b111ce41a4265d3e8986308c01b0a3482151dbb1" alt=""
如何操作数据库?
全部执行:
data:image/s3,"s3://crabby-images/4e0e1/4e0e1ca0e10755a98a7762fcd79f4e558a857638" alt=""
快捷键 ctrl +enter
单步执行:
data:image/s3,"s3://crabby-images/d9145/d9145458798785e6b1de95cda600321bba7bf80a" alt=""
如何图形化为表中添加数据?
data:image/s3,"s3://crabby-images/5b8df/5b8df3603a6868ba1b43547bfb1376e2b66f1208" alt=""
data:image/s3,"s3://crabby-images/d1392/d1392497991b3f32371c8bfd2e1174c7b5673369" alt=""
创建RE图:
data:image/s3,"s3://crabby-images/f4063/f4063502ba31cc64ba91ac23f5ddedcf90b5b857" alt=""
一路next,选择自己的数据库
data:image/s3,"s3://crabby-images/15aab/15aabc0125cc6ee31a09bd6e3c3399d903fffee6" alt=""
十、DML
1、添加数据
①、添加数据
insert into 表名(列名1,列名2.。。。列名n) values (值1,值2,。。。,值n);
insert into stu(id,name,nianling,score,sex) values(1,'范冰冰',18,59,'女');
②、如果给所有列添加值,可以不写列名;
insert into stu values(2,'佟丽娅',24,99,null,null,'优秀','女');
注意:除了数字类型,其他类型需要使用单/双引号 引起来。
data:image/s3,"s3://crabby-images/095fa/095fadc70a7eccd56c85ec0fbde492aa402d9860" alt=""
2、删除数据
如果MySql运行在safe-updates模式下,该模式会导致非主键条件下无法执行update或者delete命令。输入如下命令退出此模式:
SET SQL_SAFE_UPDATES = 0;
①删除数据
delete from 表名 where 条件;
data:image/s3,"s3://crabby-images/0b55f/0b55f22e1c68ad3729e5d3c0d65dca9f3ff14973" alt=""
②、删除所有数据
delete from 表名;
data:image/s3,"s3://crabby-images/3f39f/3f39fbb10847beb85fbd13e6f22c3ac2248ff7a0" alt=""
③、删除整个表
truncate table 表名;
3、修改数据
①、修改数据
update 表名 set 列名1=值1,列名2=值2,......列名n=值n,where 条件;
data:image/s3,"s3://crabby-images/831db/831dbc3d43ee8b8cfcb1ed6ce1b2f60b34e0dfa6" alt=""
注意:1、执行此命令同样需要退出SAFE_UPDATES模式
SET SQL_SAFE_UPDATES = 0;
2、如果不加where就会把表里的数据都改了
十一、DQL
1、语法
select
字段列表
from
表名列表
where
条件列表
group by
分组字段
having
分组之后的条件限定
order by
排序
limit
分页限定
2、基础查询
①、多个字段查询
select 列名1,列名2 from 表名;
data:image/s3,"s3://crabby-images/53f98/53f9810f962363c96b77a41eb62acc791326ab5c" alt=""
②、去除重复
SELECT DISTINCT 列名1,列名2 from 表名;
data:image/s3,"s3://crabby-images/571dc/571dcdab7f3bca469ea29c6f2430ddbc5e19aa28" alt=""
③、计算列
SELECT 列名1+列名2 from 表名;
data:image/s3,"s3://crabby-images/74f59/74f59724bdbdd0b72b4f69aa3d4426f637431351" alt=""
上面例子中柳青的成绩相加不对,原因处在null上,所以应引入ifnull判断
data:image/s3,"s3://crabby-images/b645d/b645df7d8ed8ff0ee3dc4b11b1518b7cbf21e93a" alt=""
附:判断null ifnull(列名,替换值); 当列名出现null时替换为替换值
④、起别名
select 字段名 as 别名 from 表名; #as也可以用空格代替
data:image/s3,"s3://crabby-images/944ca/944ca620b7cf793bf82641030d9e46477c3903a9" alt=""
起别名后任何位置都可以用别名代替此名。
3.条件查询
①、where后跟条件
data:image/s3,"s3://crabby-images/7fe68/7fe682a7ed0c66de0434f7bd5b20332d6514f6b8" alt=""
②、运算符
< >= <= = != <>(这个也是不等于)
....(1) and 并且
select id,name from student where age>10 and age <20;
....(2) between 条件1 and 条件2
select id,name from student where age between 10 and 20;
....(3) or 或者
select id,name from student where score>90 or age<10;
....(4) in (22,18,15); #在。。。中
select id,name from student where name in ("西施","貂蝉","王昭君");
....(5) is null //判断是null
select id,name from student where name is null;
....(6) is not null //判断不是null
select id,name from student where name is not null;
注意:null不能用 =来判断 需要用 is来判断
data:image/s3,"s3://crabby-images/a4a87/a4a87d96a6d42163cdb955adc42a57facca7f0ab" alt=""
③、LIKE 模糊查询运算符
占位符:_单个任意字符 %多个任意字符
data:image/s3,"s3://crabby-images/c6600/c66004758388dc7f99ec707045675e2ce0180bc5" alt=""
data:image/s3,"s3://crabby-images/6c148/6c14873105f616bc4106c2846c503aaef1cd9b3e" alt=""
4.排序查询
①语法
order by 排序字段1 排序方式1,排序字段2 排序方式2,。。。。
其中排序方式: ASC:升序(默认) DESC:降序
data:image/s3,"s3://crabby-images/31ff6/31ff6885e085a902a9b9dac331563ed9aaf06f77" alt=""
data:image/s3,"s3://crabby-images/55331/5533116baac96003d28dd39522b23eddadb8885d" alt=""
5、聚合函数
将一列数据按照一个整体进行计算 #列的纵向计算
①、count 计算个数
select count(列名) from 表名;
data:image/s3,"s3://crabby-images/3b776/3b77617865e8528949fbb27d7ee6f7c38524f1ff" alt=""
②、max 最大值
select max(列名) from 表名;
data:image/s3,"s3://crabby-images/89e26/89e2685fbe2474cb46d233afc32cefdf2e45da96" alt=""
③、min
select min(列名) from 表名;
④、sum
select sum(列名) from 表名;
data:image/s3,"s3://crabby-images/d605f/d605fb9b7d0afa4f344b0100683048c8b9a792aa" alt=""
⑤、avg
select avg(列名) from 表名;
data:image/s3,"s3://crabby-images/66a16/66a167fbd67063bedd239c09c546812253371d8f" alt=""
注意:聚合函数会排除null
6、分组查询
①、语法
group by 列名;
data:image/s3,"s3://crabby-images/6f974/6f974bb26d5cb29c95ea6ca25c5d9aca0f137773" alt=""
注意:分组后应该查询 分组或聚合函数才有意义。
②、分组加条件where
data:image/s3,"s3://crabby-images/92134/92134a8a7cd440eb7f611f9ffc60e5f97d9cc59b" alt=""
③、分组加条件where,完成分组后再加having筛选
data:image/s3,"s3://crabby-images/d4adc/d4adc9de3b6db240ef6f4f7280a5b97ccc9eca35" alt=""
where和having的区别:
-where在分组前限定,having再分组后限定
-where后不可以跟聚合函数 having后可以
④、分页查询
limit 开始的索引 ,每页查询的条数;
开始的索引=(当前页码-1)*3
data:image/s3,"s3://crabby-images/2ff79/2ff790e02cc47dee22842c2267e10979fb6679fa" alt=""
注意:分页操作是一个“方言”,只能用于MySQL。
十二、约束
约束是对输入数据库的数据进行限定,为了保证数据的正确性、有效性、完整性!
1、主键约束 primary key
主键表示非空且唯一,每张表只能有一列主键,主键是记录的唯一标识
①、创建时约束
data:image/s3,"s3://crabby-images/7b5d2/7b5d2ffe195bff1bca2c1df7aec5826b371e0f2d" alt=""
②、追加约束
alter table stu modify id int PRIMARY KEY;
③、删除约束
alter table stu drop primary key;
④、主键自动增长
如果一个列是数值类型的,那么可以使用auto_increment 让其自动增长,一般配合主键来用。
data:image/s3,"s3://crabby-images/09952/0995295a0c069712edb7e7e863ed21d61de6d186" alt=""
注意:自动增长只与上一条数据有关系
⑤、追加主键自动增长
alter table stu modify id int AUTO_INCREMENT;
⑥、删除主键自动增长(其实就是修改列的数据类型)
alter table stu modify id int;
2、非空约束 not null
①、创建时约束
data:image/s3,"s3://crabby-images/51ffb/51ffbe8aea46ee20dceba3353ce1853f423f6671" alt=""
②、追加约束(其实就是修改列的数据类型)
alter table stu modify name varchar(10) NOT NULL;
③、删除约束 (其实就是修改列的数据类型)
alter table stu modify name varchar(10);
3、唯一约束 unique
①、创建时约束
data:image/s3,"s3://crabby-images/64446/6444671437846568f0534bd755990c836b15d997" alt=""
②、追加约束(其实就是修改列的数据类型)
alter table stu modify phone varchar(10) unique;
③、删除约束 #此语法有些特殊
alter table stu drop index phone;
注意,唯一并不限定null
4、外键约束 foreign key
外键:让表格中的一列数据关联其他表的数据
①、创建时约束
create table 表名(
。。。。
外键列,
constraint 外键名称 foreign key(要连接外键的列名) references 主表名称(主列表名称)
);
data:image/s3,"s3://crabby-images/14a0b/14a0b0ba41c8cb192809a9c96f00405f8b1873c9" alt=""
②、追加约束
alter table 表名 add constraint 随意取一个外键约束名 foreign key (本表列名) references 外键(外键列名);
③、删除约束
alter table stu drop foreign key 外键名;
④、级联更新
设置级联更新 来确保被外键数据改动,本表的关联外键的数据一起改动
在外键后添加级联ON UPDATE CASCADE
data:image/s3,"s3://crabby-images/e272f/e272f88ef8280e11293a4a691004d72bb8c2df5f" alt=""
此时修改外键数据,本表数据会随之改变
data:image/s3,"s3://crabby-images/66a89/66a897fcbbc65db92b225f7df6e520c65ae89b5c" alt=""
⑤、级联删除
在外键后添加级联ON DELETE CASCADE
网友评论