Mysql基础

目录

  • 一、DCL(数据库控制语言)
    • [1.1 管理用户](#1.1 管理用户)
    • [1.2 权限控制](#1.2 权限控制)
  • 二、函数
    • [2.1 字符串函数](#2.1 字符串函数)
    • [2.2 数值函数](#2.2 数值函数)
    • [2.3 日期函数](#2.3 日期函数)
    • 2.4
  • 三、约束
  • 四、多表查询
    • [4.1 内连接查询](#4.1 内连接查询)
    • [4.2 外连接](#4.2 外连接)
    • [4.3 自然连接](#4.3 自然连接)
    • [4.4 联合查询](#4.4 联合查询)
    • [4.5 子查询](#4.5 子查询)
  • 五、事务
  • [5.1 事务操作](#5.1 事务操作)
    • [5.2 事务四大特性](#5.2 事务四大特性)
    • [5.3 并发事务问题](#5.3 并发事务问题)
    • [5.4 事务隔离级别](#5.4 事务隔离级别)

一、DCL(数据库控制语言)

1.1 管理用户

查询用户

bash 复制代码
select * from user;

创建用户

bash 复制代码
create user 'username'@'主机' identified by 'password'

修改密码

bash 复制代码
alter user '用户名'@'主机' indentified with mysql_native_password by 'newPassword'

删除用户

bash 复制代码
drop user '用户名'@'主机'

1.2 权限控制

查询权限

bash 复制代码
show grants for '用户名'@'主机'

授予权限

bash 复制代码
grant 权限列表 on 数据库.表名 to '用户名'@'主机'

撤销权限

bash 复制代码
revoke 权限列表 on 数据库.表明 from '用户名'@'主机'

二、函数

2.1 字符串函数

2.2 数值函数

2.3 日期函数

2.4

三、约束

保证数据库中数据的正确性、有效性和完整性

例如:

添加外键

复制代码
alter table 表名 add constraint 外键名称 foreign key 外键字段名(id) references 主表(id)

删除外键

复制代码
alter table 表名 drop foreign key 外键字段名

外键约束删除/更新行为

复制代码
alter table 表名 add constrain 外键名称 foreign key 外键字段名(id) references 主表(id) on update cascade on delete cascade 

四、多表查询

分为一对一,一对多,多对多三种形式

  • 一对多的表在设计时采用在多的一方添加一个外键来管理
  • 多对多的表在设计时采用第三个表来存储其他两个表的主键来管理,通过中间表来维护
  • 一对一的表在任意一方加入外键, 关联另外一方的主键,并且设置外键为唯一的(UNIQUE)

4.1 内连接查询

复制代码
select * from course,teacher where course.tid = teacher.tid; //隐式
或
select * from course join teacher on course.tid = teacher.tid;//显式

4.2 外连接

复制代码
//左连接:查询course表的数据和course,teacher 交集的部分
select * from course left join teacher on course.tid = teacher.tid;
//右连接:查询teacher 表的数据和course,teacher 交集的部分
select * from course right join teacher on course.tid = teacher.tid;

4.3 自然连接

自己连接自己,必须起别名

复制代码
select a.name,b.name from emp a ,emp b where a.managerid =  b.id

4.4 联合查询

复制代码
select * from A
union all //直接将两个表的数据合并
select * from B

select * from A
union //将两个表的数据合并,并去重
select * from B

4.5 子查询

复制代码
//标量子查询:返回单个值
seLect * from emp where dept_ id = (select id from dept where name = ' 销售部');

//列子查询:返回一列多行
select * from emp where dept_ id in (select id from dept where name = ' 销售部' or name = '市场部');

//行子查询:返回一行多列
select * from emp where ( salary , managerid) = (seLect salary, managerid from emp where name = ' 张无忌')

//表子查询:返回多行多列
select * from emp where (job,salary) in (selectjob, salary from emp where name ='鹿杖客' or name='宋远桥' );

五、事务

5.1 事务操作

复制代码
//查看事务
select @@autocommit
//设置事务为手动
set @@autocommit=0
//提交事务
commit
//回滚事务
rollback

5.2 事务四大特性

5.3 并发事务问题

5.4 事务隔离级别

复制代码
//查看事务隔离级别
 select @@transaction_isolation;
//设置事务隔离级别
set [session|global] transaction isolation level 隔离级别
相关推荐
像风一样!3 小时前
MySQL Galera Cluster部署如何实现负载均衡和高可用
数据库·mysql
last_zhiyin4 小时前
Oracle sql tuning guide 翻译 Part 6-4 --- Hint使用准则和Hint使用报告
数据库·sql·oracle·sql tunning
chenchihwen5 小时前
AI代码开发宝库系列:FAISS向量数据库
数据库·人工智能·python·faiss·1024程序员节
小光学长5 小时前
基于Vue的课程达成度分析系统t84pzgwk(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
前端·数据库·vue.js
摇滚侠6 小时前
全面掌握PostgreSQL关系型数据库,备份和恢复,笔记46和笔记47
java·数据库·笔记·postgresql·1024程序员节
周杰伦fans6 小时前
Navicat - 连接 mysql 、 sqlserver 数据库 步骤与问题解决
数据库·mysql·sqlserver
csdn_aspnet7 小时前
如何在 Ubuntu 24.04/22.04/20.04 上安装 MySQL 8.0
linux·mysql·ubuntu
码以致用7 小时前
StarRocks笔记
数据库·starrocks·olap·1024程序员节
auspicious航7 小时前
PostgreSQL数据库关于pg_rewind的认识
数据库·postgresql·oracle
最好结果8 小时前
MyBatis 精确查询逗号分隔字符串
mysql·mybatis·1024程序员节