数据库优化
SQL介绍&常见的数据类型
SQL
SQL是结构化查询语言,是一种用来操作RDBMS(关系型数据库管理系统)的数据库语言,当前关系型数据库都支持使用SQL语言进行操作,也就是说可以通过SQL操作oracle,sql server,mysql等关系型数据库。
SQL语句
- DQL:数据查询语言,用于对数据进行查询,如select
- DML:数据操作语言,对数据进行增加、修改、删除,如insert、update、delete
- DDL:数据定义语言,进行数据库、表的管理等,如create、drop
重点是数据的crud(增删改查),必须熟练编写DQL、DML,能够编写DDL完成数据库、表的操作
数据完整性
在表中为了更加准确的存储数据,保证数据de正确有效,可以在创建表的时候,为表添加一些强制性的验证,包括数据字段的类型、约束
常见的数据类型
- 整数:int
- 小数:decimal
- 字符串:varchar,char
- 日期时间:date,time,datetime
- 枚举类型:enum
特别说明的类型
decimal表示浮点数,如decimal(5,2)表示共存五位数,小数占2位(float也可以)
char表示固定长度的字符串,如char(3),如果填充’ab’时会补一个空格为’ab’,即’ab '。
varchar表示可变长度的字符串,如varchar(3),填充’ab’时就会存储’ab’
字符串text表示存储大文本,当字符大于4000时推荐使用
对于图片、音频、视频等文件,不存储在数据库中,而是上传到某个服务器上,然后在表中存储这个文件的保存路径
更全的数据类型参考:数据类型
数值类型
类型 | 字节大小 | 有符号范围(Signed) | 无符号范围(Unsigned) |
---|---|---|---|
TINYINT | 1 | -123~127 | 0~255 |
SMALLINT | 2 | -32768~32767 | 0~65535 |
MEDIUMINT | 3 | -8388608~8388607 | 0~1677215 |
INT/INTEGER | 4 | -2147483648~2147483647 | 0~4294967295 |
BIGINT | 5 | -9223372036854775808~9223372036854775807 | 0~18446744073709551615 |
字符串
类型 | 字节大小 | 示例 |
---|---|---|
CHAR | 0~255 | 类型:char(3)输入‘ab’,实际存储为’ab’,输入’abcd’实际存储为’abc’ |
VARCHAR | 0~255 | 类型:varchar(3)输入‘ab’,实际存储为’ab’,输入’abcd’实际存储为’abc’ |
TEXT | 0~65535 | 大文本 |
日期时间
类型 | 字节大小 | 示例 |
---|---|---|
DATE | 4 | ‘2020-01-01’ |
TIME | 3 | ‘12:29:59’ |
DATETIME | 8 | ‘2020-01-01 12:29:59’ |
YEAR | 1 | ‘2017’ |
TMESTAMP | 4 | ‘1970-01-01 00:00:01’ UTC ~ ‘2038-01-01 00:00:01’ UTC |
数据库约束
约束
- 主键primary key:物理上存储的顺序
- 非空not null:此字段不允许填写空值
- 惟一unique:此字段的值不允许重复
- 默认default:当不填写此值时会使用默认值,如果填写时以填写为准
- 外键foreign key:对关系字段进行约束,当为关系字段填写值时,会到关联的表中查询此值是否存在,如果存在则填写成功,如果不存在则填写失败并抛出异常
FIELD 'name' doesn't have a default value # 字段‘name’没有默认值 空的字符串 非空 '' # 不允许空值
Duplicate entry '1' for key 'card' # 重复条目
数据库操作
数据库的操作
-
连接数据库
mysql -u root -p root
mysql -uroot -p -
退出的数据库
exit/quit -
sql语句最后需要有分号;作结尾
-
显示数据库版本
select version(); -
查看所有数据库
show databases;
-
DDL(数据定义语句)
-
创建数据库
create database python01;
create database python01 charset=utf8;
-
查看创建数据库的语句
show create database python04;
-
查看当前使用的数据库
select database();
-
使用数据库
-
use 数据库的名字
use python01;
-
删除数据库
-
drop database 数据库名;
drop database python01;
数据表操作
数据表的操作
-
查看当前数据库中所有表
show tables; -
创建表
-
auto_increment表示自动增长
-
not null 表示不能为空
-
primary key 表示主键
-
default 默认值
-
create table 数据库表名字(字段 类型 约束[,字段 类型 约束])
create table demo1 (id int,name varchar(30));
create table demo2(
id int printmary key not null auto_incremen,
name varchar(30)
);
-
查看表结构
-
desc 数据表的名字;
desc demo2;
-
创建students表(id、name、age、high、gender、cls_id)
create table students(
id int not null primary key auto_increment,
name varchar(30),
age tinyint default 18,
high decimal(5,2),
gender enum(‘男’,‘女’,‘保密’) default ‘保密’, (存数据的时候只能存 男或女)
cls_id int
);
-
无符号:unsigned
-
创建classes表(id、name)
create table classes(
id int primary key not null auto_increment,
name varchar(30)
);
- -
查看表的创建语句
-
show create table 表名字;
show create table students;
数据表数据新增
数据表数据修改
-
修改表-添加字段
-
alter table 表名 add 列名 类型;
alter table students add birthday date; -
修改表-修改字段:不重命名版
-
alter table 表名 modify 列名 类型;
alter table students modify birthday date default ‘1990-1-1’; -
修改表-修改字段:重命名版
-
alter table 表名 change 原名 新名 类型及约束;
alter table students change birthday birth date default ‘1990-1-1’; -
修改表-删除字段
-
alter table 表名 drop 列名;
alter table students drop high; -
删除表
-
drop table 表名;
-
drop database 数据库;
增删改查curd
- 增加
–全列插入
–insert [into] 表名 values(…)
–向classes表中插入 一个班级
insert into classes values(1,‘单身班’);
–向classes表插入一个学生信息
– 主键字段 0 null default 来占位
insert into students values(0,‘居然’,18,‘男’,1,‘1990-1-1’); – id是多少?
insert into students values(null,‘juran’,19,‘男’,1,‘1990-1-1’);
insert into students values(default,‘hanhan’,19,‘男’,1,‘1990-1-1’);
–枚举类型插入 下标是从1开始的
insert into students values(default,‘xiaowang’,19,1,1,‘1990-1-1’);
–部分插入
–insert into 表名(列1,…) values(值1,…) --非空字段
insert into students(
insert into students(‘name’,‘gender’) values(‘xw’,2);
–多行插入
insert into students values
(default,‘juran’,19,‘男’,1,‘1990-1-1’),
(default,‘666’,20,‘男’,1,‘1990-1-1’);