DDL
DDL的含义:数据定义语言,主要是对于库和表的管理
一、数据库的操作
数据库的操作主要有创建数据库、修改数据库、删除数据库等操作。 1.创建数据库
create database 数据库名称;
create database if not exists 数据库名称;
create database 数据库名称 character set 字符集名;
2.查询数据库
use 数据库名称;
show databases;
show create database 数据库名称;
select database();
3.修改数据库
alter database 数据库名称 character set 字符集名称;
4.删除数据库
drop database if exists 数据库名称;
二、数据表的操作
1.表的创建
create table 表名(
列名1 数据类型1 【字段约束】,
列名2 数据类型2 【字段约束】,
....
列名n 数据类型n 【字段约束】
);
注意: 最后一列不需要加逗号! 2.查询表
show tables;
show tables from 数据库名称;
desc 表名;
3.表的修改
alter table 表名 rename to 新表名;
alter table 表名 character set 字符集名称;
alter table 表名 add column 列名 数据类型;
alter table 表名 change column 列名 新列别 新数据类型;
alter table 表名 modify column 列名 新数据类型;
alter table 表名 drop column 列名;
4.表的删除
drop table if exists 表名;
三、MySQL的常用数据类型
MySQL的常用数据类型主要分为三大类:数值型、字符型、日期型。 其中数字型又分为整数和小数,小数又分为浮点型和定点型。 1.数值型 整数: 特点
- 如果不设置无符号还是有符号,默认是有符号,若想设置无符号需添加关键字 unsigned
- 如果插入的数值超出了整型的范围,会报 out of range 异常,并且插入临界值
- 如果不设置长度,会有默认的长度 长度代表了最大显示宽度,如果不够会用0在左边填充,但必须搭配zerofill使用
小数 特点
- M代表整数部位+小数部位
- D代表小数部位
- 如果超过范围,则插入临界值
- M和D都可以省略
- 如果是decimal,则M默认为10,D默认为0
- 如果是float和double,则会随着插入的数值精度来改变
- 定点型的精度较高
2.字符型 较短的文本 char
- 固定长度的字符,比较耗费空间,效率较高,M可以省略,默认为1
varchar
- 可变长度的字符,比较节省空间,效率较低,M不可以省略
保存较长的文本 text、blob(较大的二进制)都是用来存储较长文本的
其他字符型
- binary和varbinary用于保存较短的二进制
- enum用于保存枚举
- set用于保存集合
3.日期型 注意:
- date只保存日期
- time 只保存时间
- year 只保存年
- datetime 保存日期+时间
范围1000-9999 不受时区的影响 - timestamp 保存日期+时间
范围1970-2038 受时区的影响
四、常见约束
概念: 对表中的数据进行限定,保证数据的正确性、有效性和完整性。 分类: not null 非空约束,用于保证该字段的值不能为空 default 默认值约束,用于保证该字段有默认值 primary key 主键约束,用于保证该字段的值具有唯一性,并且为非空,一个表中只能有一个,允许组合 unique 唯一约束,用于保存该字段的值具有唯一性,可以为空,但空值只能有一个,一个表中可以有多个,允许组合 check 检查约束,判断字段的值是否在是指定规定的值
foreign key外键约束,用于限制两个表的关系,用于保证该字段的值必须来自于主表的关联列的值
- 在从表添加外键约束,用于引用主表中某列的值
- 要求在从表设置外键关系
- 从表的外键列的类型和主表的关联列的类型要求一致或兼容
- 主表的关联列必须是一个key(一般是主键或唯一)
- 插入数据时,先插入主表,再插入从表
- 删除数据时,先删除从表,在删除主表
约束的添加时机一般在我们创建表和修改表时。 约束添加的分类: 列级约束、表级约束 列级约束
- 六大约束语法上都支持,但外键约束没有效果
- 直接在字段名和类型后面追加约束即可
表级约束 - 除了非空、默认,其他的都支持
- 在各个字段的最下面添加
- 语法:
【constraint 约束名 】约束类型(字段名)
查看表中的所有索引(主键、外键、唯一)
show index from 表名
添加列级约束
alter table 表名 modify column 字段名 字段类型 新约束;
添加表级约束
alter table 表名 add【constraint 约束名】 约束类型(字段名) 【外键的引用】;
DML
DML 数据操作语言 主要是对数据进行插入、修改、删除等操作 一、添加数据
insert into 表名(列名1,列名2,...列名n) values(值1,值2,...值n);
注意: 1. 列名和值要一一对应。 2. 如果表名后,不定义列名,则默认给所有列添加值 3. 除了数字类型,其他类型需要使用引号(单双都可以)引起来
二、删除数据
delete from 表名 [where 条件]
注意: 1. 如果不加条件,则删除表中所有记录。 2. 如果要删除所有记录 delete from 表名; – 不推荐使用。有多少条记录就会执行多少次删除操作 TRUNCATE TABLE 表名; – 推荐使用,效率更高 先删除表,然后再创建一张一样的表。
常见面试题: delete与TRUNCATE区别? 1.truncate不能加where条件,而delete可以加where条件 2.truncate的效率高 3.truncate 删除带自增长的列的表后,如果再插入数据,数据从1开始 4.delete 删除带自增长列的表后,如果再插入数据,数据从上一次的断点处开始 5.truncate删除不能回滚,delete删除可以回滚
三、修改数据 修改单表:
update 表名 set 列名1 = 值1, 列名2 = 值2,... [where 条件];
修改多表:
update 表1 别名1,表2 别名2 set 字段=新值,字段=新值 where 连接条件 and 筛选条件
注意: 如果不加任何条件,则会将表中所有记录全部修改
|