目录
一、SQL分类及类型
数据库对象和命名
SQL语句分类
常用的数据类型:
二、数据库管理
2.1 查看数据库信息
2.2 切换数据库
2.3 查看表
2.4 显示数据表的结构
DDL
2.5 创建新的数据库
2.6 创建新的表
2.7 删除指定的数据表
2.8 删除指定的数据库
DML
2.9 表中插入数据
2.10 修改、更新数据表的数据记录
2.11 数据表中删除指定的数据记录
DQL
2.12 查询数据记录
三、数据库高级操作
3.1 清空表,删除表内的所有数据
使用场景:
3.2 创建临时表
3.3 克隆表
DCL
3.4 修改表名
3.5 扩展表结构(增加字段)
3.6 修改字段(列)名,添加唯一键
3.7 修改字段(列)类型
3.8 删除字段
3.9 案例扩展
一、SQL分类及类型
-
数据库:database
-
表:table,行:row 列:column
-
索引:index
-
视图:view
-
存储过程:procedure
-
存储函数:function
-
触发器:trigger
-
事件调度器:event scheduler,任务计划
-
用户:user
-
权限:privilege
SQL 语言规范
-
在数据库系统中,SQL 语句不区分大小写,建议用大写
-
SQL语句可单行或多行书写,默认以 " ; " 结尾
-
关键词不能跨多行或简写
-
用空格和TAB 缩进来提高语句的可读性
-
子句通常位于独立行,便于编辑,提高可读性
数据库对象和命名
数据库的组件(对象):
数据库、表、索引、视图、用户、存储过程、函数、触发器、事件调度器等
命名规则:
必须以字母开头,后续可以包括字母,数字和三个特殊字符(# _ $)
不要使用MySQL的保留字,tabble select show databases
SQL语句分类
-
DDL: Data Defination Language 数据定义语言 ,用于创建数据库对象,如库、表、索引等
create ,drop ,alter
-
DML: Data Manipulation Language 数据操纵语言 ,用于对表中的数据进行管理,用来插入、删除和修改数据库中的数据
INSERT,DELETE,UPDATE
软件开发:CRUD
-
DQL:Data Query Language 数据查询语言 ,用于从数据表中查找符合条件的数据记录
SELECT
-
DCL:Data Control Language 数据控制语言 ,用于设置或者更改数据库用户或角色权限
(数据控制语句,用于控制不通数据段直接的许可和访问级别的语句,这些语句定义了数据库、表、字段、用户的访问权限和安全级别,如COMMIT、ROLLBACK、GRANT、REVOKE)
GRANT,REVOKE
-
TCL:Transaction Control Language 事务控制语言
COMMIT,ROLLBACK,SAVEPOINT
常用的数据类型:
int:整型 用于定义整数类型的数据
float:单精度浮点4字节32位 准确表示到小数点后六位
double:双精度浮点8字节64位 精度高达约15位小数。
char:固定长度的字符类型 用于定义字符类型数据。 20字节 4
varchar:可变长度的字符类型 20 4
text:文本
image:图片
decimal(5,2):5个有效长度数字,小数点后面有2位 指定长度数组
#Char如果存入数据的实际长度比指定长度要小,会补空格至指定长度,如果存入的数据的实际长度大于指定长度,低版本会被截取,高版本会报错
主键是唯一的,但主键可以由多个字段构成
扩展:
MySQL数据库的数据文件存放在/usr/local/mysql/data目录下,每个数据库对应一个子目录,用于存储
数据表文件。每个数据表对应为三个文件,扩展名分别为“.frm”、“.MYD”和“.MYI”。
MYD”文件是MyISAM存储引擎专用,存放MyISAM表的数据。每一个MyISAM表都会有一个“.MYD”文件与之对应,
同样存放于所属数据库的文件夹下,和“.frm”文件在一起。
“.MYI”文件也是专属于 MyISAM 存储引擎的,主要存放 MyISAM 表的索引相关信息。对于 MyISAM
存储来说,可以被 cache 的内容主要就是来源于“.MYI”文件中。每一个MyISAM 表对应一个“.MYI”文件,
存放于位置和“.frm”以及“.MYD”一样。
MyISAM 存储引擎的表在数据库中,每一个表都被存放为三个以表名命名的物理文件(frm,myd,myi)。
每个表都有且仅有这样三个文件做为 MyISAM 存储类型的表的存储,也就是说不管这个表有多少个索引,
都是存放在同一个.MYI 文件中。
另外还有“.ibd”和 ibdata 文件,这两种文件都是用来存放 Innodb 数据的,之所以有两种文件来存放
Innodb 的数据(包括索引),是因为Innodb的数据存储方式能够通过配置来决定是使用共享表空间存放
存储数据,还是独享表空间存放存储数据。独享表空间存储 方式使用“.ibd”文件来存放数据,且每个表
一个“.ibd”文件,文件存放在和 MyISAM 数据相同的位置。如果选用共享存储表空间来存放数据,则会
使用 ibdata 文件来存放,所有表共同使用一个(或者多个,可自行配置)ibdata 文件。
二、数据库管理
2.1 查看数据库信息
show databases;
2.2 切换数据库
use 数据库名;
2.3 查看表
show tables;
show tables in 数据库名;
不切换数据库查看数据库中的表。
2.4 显示数据表的结构
describe 表名;
简写: desc 表名;
Field : 字段名称
Type : 数据类型
Null : 是否允许为空
Key : 主键
Default : 默认值
Extra : 扩展属性,例如:标志符列(标识了种子,增量/步长)1 2
id:1 3 5 7
DDL
DDL:数据定义语言,用于创建数据库对象,如库、表、索引等
2.5 创建新的数据库
create database 数据库名;
2.6 创建新的表
create table 表名 (字段1 数据类型,字段2 数据类型[,...][,PRIMARY KEY (主键名)]);
#主键一般选择能代表唯一性的字段不允许取空值(NULL),一个表只能有一个主键。
create table xiao (id int not null,name char(16) not null,score decimal(4,2),passwd char(50) default'',primary key (id));
#NOT NULL: 不允许为空值
#DEFAULT'': 默认值为空
PRIMARY KEY :主键一般选择没有重复并且不为空值的字段
2.7 删除指定的数据表
use 数据库名
drop table 表名或
drop table [数据库名.] 表名;
2.8 删除指定的数据库
drop database 数据库名;
DML
DML管理表中的数据记录 ---- 数据操纵语言,用于对表中的数据进行管理,用来插入、删除和修改数据库中的数据
insert 、update 、delete
2.9 表中插入数据
insert into 表名(字段1,字段2[,...]) VALUES (字段1的值,字段2的值,...);
insert into xiao (id,name,score,passwd) values (1,'ming',66.66,PASSWORD('123456'));
#PASSWORD('123456'):查询数据记录时,密码字串以加密形式显示:若不使用PASSWORD(),查询时以明文显示。
#select * from 表名; 查询表的数据记录
不加字段在表中添加数据
insert into xiao values(2,'hong',77.77,852741);
2.10 修改、更新数据表的数据记录
update 表名 set 字段名1=字段值1[,字段名2=字段值2] [where 条件表达式];
update xiao set score=11 where id=1;
update xiao set name='xing',score=66 where id=2;
update xiao set passwd=PASSWORD('656481') where id=2;
2.11 数据表中删除指定的数据记录
delete from 表名 [where id=2];
delete from xiao where id=2;
#这里不指定就删除表中的全部数据
DQL
DQL查询数据记录
select
2.12 查询数据记录
select 字段名1,字段名2[,...] FROM 表名[WHERE 条件表达式];
select * from xiao;
select id,name,score from xiao where id=3;
select * from xiao\G #以列表方式竖向显示
select * from xiao limit 2; #只显示头2行
select * from xiao limit 2,3; #显示第2行后的前3行
三、数据库高级操作
3.1 清空表,删除表内的所有数据
方法一:
delete from 表名;
#DELETE清空表后,返回的结果内有删除的记录条目;
DELETE 工作时是一行一行的删除记录数据的;如果表中有自增长字段,使用DELETE FROM 删除
所有记录后,再次新添加的记录会从原来最大的记录ID后面继续自增写入记录。
比如说原来的表id设置了自增长(每添加一行自动加一),使用delete清空表内的数据后添加行的id将继续接着原表id写入。(原来id增长到5,delete清空后添加行id从6开始)
方法二:
truncate table 表名;
#TRUNCATE清空表后,没有返回被删除的条目
TRUNCATE 工作时是将表结构按原样重新建立
因此在速度上 truncate 会比 delete 清空表快;使用truncate table 清空表内数据后,ID会从1开始重新记录
小结:关于drop、truncate、delete的区别
#删除类型
drop table table_name;
1)属于DDL
2)不可回滚(无法恢复)
3)不可带where
4)表内容和结构删除
5)删除速度快
truncate table table_name;
1)属于DDL
2)不可回滚
3)不可带where
4)表内容删除
5)删除速度快
delete from table_name;
1)属于DML
2)可回滚(可恢复)
3)可带where
4)表结构在,表内容要看where执行的情况
5)册删除速度慢,需要逐行删除
使用场景:
不再需要一张表的时候,用drop
想删除部分数据行时候,用delete,并且带上where子句
保留表而删除所有数据的时候用truncate
速度:drop> truncate > delete
安全性 :delete 最好
3.2 创建临时表
临时表创建成功之后,使用 show tables; 命令是看不到创建的临时表的,临时表会在连接退出后被销毁。
如果在退出连接之前,也可以可执行增删改查等操作,比如使用 DROP TABLE 语句手动直接删除临时表。
PS:无法创建外键
create temporary table 表名 (字段1 数据类型,字段2 数据类型[, ...] [, PRIMARY KEY (主键名)]);
示例:
create temporary table xuni (id int(5) zerofill primary key auto_increment,name char(15) not null,card int(18) not null unique key,aihao varchar(60));
int(5) zerofill :表示若数值不满5位数,则前面用"0"填充,例00001
auto_increment :表示此字段为自增长字段,即每条记录自动递增1,默认从1开始递增;
自增长字段数据不可以重复;自增长字段必须是主键;如添加的记录数据没有指定此字段的值且
添加失败也会自动递增一次
unique key :表示此字段唯一键约束,此字段数据不可以重复:一张表中只能有一个主键,但是一张表中可以有多个唯一键
not null :表示此字段不允许为NULL
在虚拟表中添加数据
insert into xuni (name,card,aihao) values ('xun',1214514785,'play');
看不到创建的临时表
退出后虚拟表就没有了
3.3 克隆表
保留格式复制:
create table xiao2 like xiao; #复制格式,通过LIKE方法,复制yyy表结构生成yyy2表
insert into xiao2 select * from xiao; #备份内容
保留数据:将数据表的数据记录生成到新的表中
create table xiao3 (select * from xiao); #复制xiao 表数据到 xiao3中
show create table 表名\G; #获取数据表的表结构、索引等信息
DCL
3.4 修改表名
alter table 旧表名 rename 新表名;
3.5 扩展表结构(增加字段)
alter table 表名 add address varchar(50) default '地址不详';
#address表示家庭住址。
#default '地址不详':表示此字段设置默认值为地址不详,可与NOT NULL配合使用
alter table huhu add address varchar(50) not null default '地址不详';
在添加的字段中添加数据
update huhu set address='华北新城东街29号' where id=1;
3.6 修改字段(列)名,添加唯一键
alter table 表名 change 旧列名 新列名 数据类型 [unique key];
unique key:唯一键(特性:唯一,但可以为空,空值只允许出现一次)
Primary key:唯一且非空(主键一般选择能代表唯一性的字段不允许取空值(NULL),一个表只能有一个主键。)
alter table huhu change name names varchar(10) unique key;
#CHANGE可修改字段名、数据类型、约束等所有项。
3.7 修改字段(列)类型
谨慎修改类型,可能会导致原有数据出错
alter table 表名 modify column 字段名 数据类型;
数据库中表 字段是varchar(30),修改类型可以用
3.8 删除字段
alter table 表名 drop 字段名;
alter table huhu drop address;
3.9 案例扩展
create table if not exists hong (id int(4) zerofill primary key auto_increment,
name varchar(12) not null,
cardid int(18) not null unique key,
hobby varchar(60));
#if not exists:表示检测要创建的表是否已存在,如果不存在就继续创建
#int(4) zerofill:表示若数值不满4位数,则前面用"0"填充,例0001
#auto_increment:表示此字段为自增长字段,即每条记录自动递增1,默认从1开始递增;
自增长字段数据不可以重复;自增长字段必须是主键;如添加的记录数据没有指定此字段的值且
添加失败也会自动递增一次
#unique key:表示此字段唯一键约束,此字段数据不可以重复:一张表中只能有一个主键,但是一张表中
可以有多个唯一键
#not null:表示此字段不允许为NULL