一.安装MySQL
1.常用MySQL5.7,首先安装MySQL,
(一)
data:image/s3,"s3://crabby-images/a9035/a9035c6b3f4a748be131b9b6fc92e15fb1994962" alt=""
(二)
data:image/s3,"s3://crabby-images/ef22c/ef22cf51b42603bb74f90d17f9349831fb460d57" alt=""
(三)
data:image/s3,"s3://crabby-images/c010d/c010df6341e1e4bc0271697fb432faf93413190e" alt=""
(四)
data:image/s3,"s3://crabby-images/ec6ab/ec6abb45f967d4e6a6031e4573bda99a52485b44" alt=""
(五)
data:image/s3,"s3://crabby-images/6204d/6204dafaf8587b1fa6a2f53220c41c54854639b1" alt=""
2.配置环境变量
打开MySQL安装路径,在其中找到bin文件,复制路径,打开系统高级设置,点击环境变量,在下方找到path,将bin文件路径粘贴其中。
3.检验安装是否完成
win + r 输入cmd,打开命令提示符,输入指令:net start | find "MySQL",这将显示正在运行的服务中是否包含 MySQL。如果 MySQL 服务正在运行,你会看到类似 MySQL 的输出。
4.连接mysql
指令:mysql -u root -p,回车后会提示输入root密码,如果连接成功,你将进入 MySQL 的命令行界面。
data:image/s3,"s3://crabby-images/d020b/d020b1abf504ae3f467ba3179884f6e8e12468ab" alt=""
二.MySQL常用指令
1.数据库
create database 数据库名 charset=utf8; 创建数据库
show databases; 显示所有数据库
data:image/s3,"s3://crabby-images/5b44c/5b44cf7c0165c226e421afe8df81303d6131ae69" alt=""
use 数据库名; 使用数据库名
data:image/s3,"s3://crabby-images/ce26e/ce26e314999437c0dc65591f54cb27d9c52f91bf" alt=""
drop database 数据名; 删除数据库
2.数据表
show tables; 显示数据库中所有表
data:image/s3,"s3://crabby-images/cdc0e/cdc0ef8e259160a59787be6a13df80c41718e978" alt=""
create table 表名 (列名 类型 约束1 约束2,列名 类型 约束1 约束2,...); 创建表
data:image/s3,"s3://crabby-images/44a81/44a817c6b8b3c41f444c70dd9262bbad0f52de0f" alt=""
desc 表名; 查看表结构
data:image/s3,"s3://crabby-images/2f496/2f4965ae289d58342cdefb575477201ef944e58a" alt=""
data:image/s3,"s3://crabby-images/88555/88555bdec1a6a285d3ff5b5a9872444b785ecdfe" alt=""
删除列名
data:image/s3,"s3://crabby-images/934d5/934d53725d651869cae09884c1cf21adb2a90b14" alt=""
添加列名
data:image/s3,"s3://crabby-images/33790/33790fdc0bf5bb15c3b15e95c30f4019b71fef3a" alt=""
修改列名
data:image/s3,"s3://crabby-images/feaf5/feaf5da09b45914a50a8b526cb0a2302d99d75a2" alt=""
3.约束
主键: primary key
非空:not null
自增长:auto_increment
唯一:unique
默认值:default
外键:foreign key
检查:check (mysql8才能用)
4.增删改查
(1)查
select * from 表名; 适用于表中数据相对较少时
select 列名,列名 from 表名;
select 列名 as 别名,列名 as 别名 from 表名;
1.1.where 条件
比较运算符 = >= > <= < != <>
逻辑运算符 and or not
判空 is null, is not null
精确比较 in in [a, b, c]
范围比较 between and between 5 and 10
像 like % 代表多个字符 _ 一个字符
1.2.关联查询
嵌套查询
第一次查询的结果作为第二次查询的条件
表连接
笛卡尔连接
一个表中每一行都和另外一个表中所有行连接
内连接
inner join
例子:select user.id as 用户id, user.username as 用户名, role.nick as 昵称, role.level as 等级 from user inner join role on user.id = role.user_id;
外连接
左外连接 left join 以左表为主,左表条件满足 正常显示 不满足 右侧补null
例子:select * from user left join role on user.id = role.user_id;
右外连接 right join 以右表为主,右表条件满足 正常显示 不满足 左侧补null
例子:select * from role right join user on user.id = role.user_id;
全连接
left join union right join
例子: select * from user right join role on user.id = role.user_id union select * from user left join role on user.id = role.user_id;
1.3.去重,分组,排序,分页
去重
distinct 单独列展示 并对列去重
例子: select distinct user_id from role;
分组
group by
一般结合count(*)进行统计
例子: select info as '组信息', count(*) as 个数 from role group by info;
排序
列排序
order by asc 升序 desc 降序
例子:select * from role order by user_id desc , id asc ;
分页
limit
一个数字n代表前n个 limit n
两个数字m n limit m , n
例子:select * from role limit 5; select * from role limit 2,2;
(2)增
insert into 表名 values (值1,值2,值3), (值1,值2,值3); 值的个数与列的个数一致
insert into 表名 (列1,列2,列3) values (值1,值2,值3); 可以指定 哪些列的数据,没有默认值的列必须插入
insert into 表名 set 列1=值1,列2=值2; 插入1行指明插入的列与其值
(3)改
update 表名 set 列1 = 值1 where 条件;
如果没有 where 条件 就修改整个表。
(4)删
delete from 表名 where 条件;
如果没有 where 条件 就清空表
5.用户
创建用户
create user '用户名'@'%' identified by '123456';
分配权限
grant 权限列举 on 数据库名.表名 to '用户名'@'%'; all 所有权限 *.* 所有数据库中的所有表
删除用户
drop user '用户名'@'%';
修改密码
alter user '用户名'@'%' identified by '123456';
6.外键
关系型数据库表与表之间存在关联关系
外键:一个表中的某一列是另外一个表中的主键
创建,添加
constraint 外键名 foreign key (列名) references 表 (列)on update cascade on
delete cascade;
删除
alter table 表名 drop foreign key 外键名;
7.函数
查看当前数据库
select database();
查看当前用户
select user();
查看版本
select version();
现在时间
select now();
当前日期
select curdate();
当前时间
select curtime();
时间戳
select unix_timestamp();
三.mysql与pycharm
首先安装对应的包,打开终端,输入:pip install pymysql
第一步:导入模块
第二步:构建连接实例
data:image/s3,"s3://crabby-images/16bd6/16bd6a2f361396fa1023c13601d264f32b682936" alt=""
user指的是用户名,
password指的是用户密码,
select_db 指的是数据库名。
第三步:构建游标
data:image/s3,"s3://crabby-images/205b3/205b33b233807eefa8e7f28ad329afaf89040787" alt=""
第四步 :关闭游标,关闭连接
data:image/s3,"s3://crabby-images/d0d19/d0d19886cc08554d888631d9aa8e628e3f42e8cb" alt=""
这样数据库就与mysql连接上了。