MySQL
启动
| |
---|
1.手动打开服务窗口 | cmd输入services.msc,找到mysql服务并选择打开 | 2.右键cmd管理员打开 | 输入 net start mysql | 3.右键cmd管理员关闭 | 输入net stop mysql |
登录
| |
---|
1.远程连接简写 | mysql -hip -uroot -p连接目标的密码 | 2.远程连接详写 | mysql --host=ip --user=root --password=连接目标的密码 | 3.本地连接 | mysql -uroot -p密码 |
退出
| |
---|
1.退出 | cmd输入exit | 2.退出 | cmd输入quit |
SQL
注释
| |
---|
1.单行注释 | – 注释内容 或 # 注释内容(mysql 特有) | 2.多行注释 | /* 注释 */ |
分类
| |
---|
1.DDL(Data Definition Language) | 用来定义数据库对象:数据库,表,列等。关键字:create, drop,alter 等 | 2.DML(Data Manipulation Language) | 用来对数据库中表的数据进行增删改。关键字:insert, delete, update 等 | 3.DQL(Data Query Language) | 用来查询数据库中表的记录(数据)。关键字:select, where 等 | 4.DCL(Data Control Language) | 用来定义数据库的访问权限和安全级别,及创建用户。关键字:GRANT, REVOKE 等 |
数据类型
简单数据类型
| |
---|
int | 整数类型 | double | 小数类型 double(5,2) --表示总共5位,小数点后面两位 | date | 日期,只包含年月日,yyyy-MM-dd | datetime | 日期,包含年月日时分秒 yyyy-MM-dd HH:mm:ss | timestamp | 时间戳类型 包含年月日时分秒 yyyy-MM-dd HH:mm:ss 默认本地时间 | varchar | 字符串 varchar(20) —表示最大20个字符 |
DDL:操作数据库、表
操作数据库:CRUD
C(Create):创建
| |
---|
1.创建数据库 | create database 数据库名称; | 2.创建数据库,判断不存在,再创建 | create database if not exists 数据库名称; | 3.创建数据库,并指定字符集 | create database 数据库名称 character set 字符集名; | 4.小结:创建db4数据库,判断是否存在,并制定字符集为gbk | create database if not exists db4 character set gbk; |
R(Retrieve):查询
| |
---|
1.查询所有数据库的名称 | show databases; | 2.查询某个数据库的字符集:查询某个数据库的创建语句 | show create database 数据库名称; |
U(Update):修改
| |
---|
1.删除数据库 | drop database 数据库名称; | 2.判断数据库存在,存在再删除 | drop database if exists 数据库名称; |
使用数据库
| |
---|
1.查询当前正在使用的数据库名称 | select database(); | 2.使用数据库 | use 数据库名称; |
操作表:CRUD
C(Create):创建
| |
---|
1. 语法 | create table 表名( 列名1 数据类型1, 列名2 数据类型2, … 列名n 数据类型n ); | 2.注意 | 最后一列,不需要加逗号(,) | 3.复制创建 | create table 表名 like 被复制的表名; |
R(Retrieve):查询
| |
---|
1. 查询某个数据库中所有的表名称 | show tables; | 2. 查询表结构 | desc 表名; --就是有哪些列 |
U(Update):修改
| |
---|
1. 修改表名 | alter table 表名 rename to 新的表名; | 2. 修改表的字符集 | alter table 表名 character set 字符集名称; | 3. 添加一列 | alter table 表名 add 列名 数据类型; | 4. 修改列名称 类型(1) | alter table 表名 change 列名 新列别 新数据类型; | 5. 修改列名称 类型(2) | alter table 表名 modify 列名 新数据类型; | 6. D(Delete):删除 | alter table 表名 drop 列名; |
D(Delete):删除
| |
---|
1.删除表(1) | drop table 表名; | 2.先判断存在再删除表(2) | drop table if exists 表名 ; |
DML:增删改表中数据
添加数据
| |
---|
1.语法 | insert into 表名(列名1,列名2,…列名n) values(值1,值2,…值n); | 2.注意 | 1. 列名和值要一一对应。 2. 如果表名后,不定义列名,则默认给所有列添加值 insert into 表名 values(值1,值2,…值n); 3. 除了数字类型,其他类型需要使用引号(单双都可以)引起来 |
删除数据
| |
---|
1.语法 | delete from 表名 where 条件 | 2.注意 | 1. 如果不加条件,则删除表中所有记录。 2. 如果要删除所有记录 - delete from 表名; – 不推荐使用。有多少条记录就会执行多少次删除操作 - TRUNCATE TABLE 表名; – 推荐使用,效率更高 先删除表,然后再创建一张一样的表。 |
修改数据
| |
---|
1.语法 | update 表名 set 列名1 = 值1, 列名2 = 值2,… where 条件; | 2.注意 | 如果不加任何条件,则会将表中所有记录全部修改。 |
DQL:查询表中的记录
标准查询
| |
---|
1.语法 | select 字段列表 from 表名列表 where 条件列表 group by 分组字段 having 分组之后的条件 order by 排序 limit 分页限定 |
基础查询
| |
---|
1. 多个字段的查询 | select 字段名1,字段名2… from 表名; | 2.全部字段查询 | select * from 表名; | 3.去除重复查询 | select distinct 字段名1,字段名2… from 表名; | 4.起别名 | as:as也可以省略 |
条件查询
| |
---|
1.where | where子句后跟条件 | 2.运算符 | 1. > 、< 、<= 、>= 、= 、<> 2. BETWEEN…AND 3. IN( 集合) 4.LIKE:模糊查询 占位符: _:单个任意字符 %:多个任意字符 5. IS NULL 6. and 或 && 7. or 或 || 8. not 或 ! |
排序查询
| |
---|
1.语法 | order by 子句 order by 排序字段1 排序方式1 , 排序字段2 排序方式2… | 2.排序方式 | ASC:升序,默认的。 DESC:降序。 | 3.注意 | 如果有多个排序条件,则当前边的条件值一样时,才会判断第二条件。 |
聚合函数
| |
---|
含义 | 将一列数据作为一个整体,进行纵向的计算 | 1.count | 计算个数 SELECT COUNT(DISTINCT column_name) FROM table_name 1. 一般选择非空的列:主键 2. count(*) | 2.max | 计算最大值,语法和上例无差 | 3.min | 计算最小值 | 4.sum | 计算和 | 5.avg | 计算平均值 | 注意 | 聚合函数的计算,排除null值。 | 解决方法 | 1. 选择不包含非空的列进行计算 2. IFNULL函数 |
分组查询
| |
---|
1.语法 | group by 分组字段; SELECT Company, OrderNumber FROM Orders ORDER BY Company; | 2.注意 | 1. 分组之后查询的字段:分组字段、聚合函数 2. where 和 having 的区别? 1. where 在分组之前进行限定,如果不满足条件,则不参与分组。having在分组之后进行限定,如果不满足结果,则不会被查询出来 2. where 后不可以跟聚合函数,having可以进行聚合函数的判断。 |
分页查询
| |
---|
1.语法 | limit 开始的索引,每页查询的条数; | 2.计算索引公式 | 公式:开始的索引 = (当前的页码 - 1) * 每页显示的条数 | 3.例子 | – 每页显示3条记录
SELECT * FROM student LIMIT 0,3; – 第1页 SELECT * FROM student LIMIT 3,3; – 第2页 SELECT * FROM student LIMIT 6,3; – 第3页 | 4.注意 | limit 是一个MySQL"方言",不同数据库语言有不同实现方式 |
约束
概念和分类
| |
---|
概念 | 对表中的数据进行限定,保证数据的正确性、有效性和完整性。 | 1.主键约束 | primary key | 2.非空约束 | not null | 3.唯一约束 | unique | 4.外键约束 | foreign key |
主键约束
| |
---|
1.注意 | 1. 含义:非空且唯一 2. 一张表只能有一个字段为主键 3. 主键就是表中记录的唯一标识 | 2.创建表时创建 | create table stu( id int primary key,-- 给id添加主键约束 name varchar(20) ); | 3.删除主键 | ALTER TABLE stu DROP PRIMARY KEY; | 4.创建完表之后添加主键 | ALTER TABLE stu MODIFY id INT PRIMARY KEY; 注意列数据要符合主键要求才能添加 | 5.创建表时为主键添加自增长 | create table stu( id int primary key auto_increment,-- 给id添加主键约束 name varchar(20) ); | 6.删除自增长 | ALTER TABLE stu MODIFY id INT; | 7.之后添加自增长 | ALTER TABLE stu MODIFY id INT AUTO_INCREMENT; |
外键约束
| |
---|
概念 | foreign key,让表于表产生关系,从而保证数据的正确性。 | 1.创建表时添加外键 | 语法: create table 表名( … 外键列 constraint 外键名称 foreign key (外键列名称) references 主表名称(主表列名称) ); –需要一个外键列 | 2. 删除外键 | ALTER TABLE 表名 DROP FOREIGN KEY 外键名称; | 3. 创建表之后,添加外键 | ALTER TABLE 表名 ADD CONSTRAINT 外键名称 FOREIGN KEY (外键字段名称) REFERENCES 主表名称(主表列名称); |
级联操作
| |
---|
概念 | 需要依托于外键添加 | 1. 添加级联操作 | ALTER TABLE 表名 ADD CONSTRAINT 外键名称 FOREIGN KEY (外键字段名称) REFERENCES 主表名称(主表列名称) ON UPDATE | 2. 分类 | 1. 级联更新:ON UPDATE CASCADE 2. 级联删除:ON DELETE CASCADE |
|