mysql-day03笔记

  • 8.6、事务的隔离性

  • 8.7、查看隔离级别

1、insert 语句一次插入多条记录

语法:

insert into t_user(字段名1,字段名2) values(),(),(),();

2、快速创建表

原理

将一个查询结果当做一张表新建!!!!!

这个可以完成表的快速复制!!!!

表创建出来,同时表中的数据也存在了!!!

语法:

create table (新表名) as select (复制的字段1),(复制的字段2)…

from (复制的表名)

where (条件);

3、将查询结果插入到一张表当中(insert)

语法:

insert into (表名) select * from (表名);

4、快速删除表中的数据

删除表中数据:

delete from (表名); //这种删除数据的方式比较慢

delete语句删除数据的原理?(delete属于DML语句)

表中的数据被删除了,但是这个数据在硬盘上的真实存储空间不会被释放!!!

这种删除缺点是:删除效率比较低。

这种删除优点是:支持回滚,后悔了可以再恢复数据!!!

4.1、使用 truncate 语句删除数据:

原理:

这种删除效率比较高,表被一次截断,物理删除。

这种删除缺点:不支持回滚。

这种删除优点:快速。

用法:

truncate table (表名); //这种操作属于 DDL 操作

讲解:

如果有一张大表非常大,有上亿条记录

删除的时候,使用delete,也许需要执行1个小时才能删除完!效率较低。

可以选择使用truncate删除表中的数据。只需要不到1秒钟的时间就删除结束。效率较高。

但是使用truncate之前,必须仔细询问客户是否真的要删除,并警告删除之后不可恢复!

truncate是删除表中的数据,表还在!

删除表操作:

drop table (表名);//不是删除表中的数据,是删除表

5、对表结构的增删改?

对表结构的修改:

添加一个字段,删除一个字段,修改一个字段

对表结构的修改需要使用:alter

属于DDL语句

DDL包括:

create drop alter

6、约束 * * * * *

6.1、什么是约束?

约束对应的英语单词:constraint

在创建表的时候,我们可以给表中的字段加上一些约束,来保证这个表中数据的

完整性、有效性!!!

作用:

约束的作用就是为了保证:表中的数据有效

6.2、约束包括哪些?

非空约束:not null

唯一性约束:unique

主键约束:primary key (简称 PK)

外键约束: foreign key (简称 FK)

检查约束:check (mysql 不支持,Oracle 支持)

重点学习这四个

not null

unique

primary key

foreign key

6.3、非空约束:not null

非空约束not null约束的字段不能为NULL。

创建表的时候在字段对应的列上加上 not null

drop table if exists (表名);//如果有就删除

create table (表名)( //创建表

id int,

name varchar(255) not null //not null 只有列级约束,没有表级约束

);

6.4、唯一性约束:unique

唯一性约束unique约束的字段不能重复,但是可以为NULL。

创建表的时候在字段对应的列上加上 unique ,与字段联合使用

drop table if exists (表名);//如果有就删除

create table (表名)( //创建表

id int,

name varchar(255) unique

);

字段联合使用:

创建表的时候在后面添加unique(要联合的字段)(表级约束)

drop table if exists (表名);//如果有就删除

create table (表名)( //创建表

id int,

name varchar(255)

email varchar(255)

unique((字段1),(字段2));//这种单独加在后面的称为表级约束

);

联合的字段看作一个整体进行唯一性约束

unique 和not null可以联合

drop table if exists (表名);//如果有就删除

create table (表名)( //创建表

id int,

name varchar(255) not null unique

);

注意:

在mysql当中,如果一个字段同时被not null和unique约束的话,

该字段自动变成主键字段。(注意:oracle中不一样!)

6.5、主键约束(primary key,简称PK)* * * * *

主键约束的相关术语:

主键约束:就是一种约束。

主键字段:该字段上添加了主键约束,这样的字段叫做:主键字段

主键值:主键字段中的每一个值都叫做:主键值。

什么是主键:

主键值是每一行记录的唯一标识。

主键值是每一行记录的身份证号

记住:

任何一张表都应该有主键,没有主键,表无效

主键的特征:

not null + unique(主键值不能是NULL,同时也不能重复!)

添加主键:

一个字段做主键,叫做:单一主键

create table (表名)(

id int primary key, //列级约束,(primary key)

name varchar(255)

);

可以使用表级约束给多个字段联合起来添加约束,叫做复合主键

create table (表名)(

id int

name varchar(255)

primary key(id,name) //表级约束,复合主键

//primary key(id) 表级约束

);

联合的约束应看作一个整体

不建议使用:

复合主键。建议使用单一主键!

原因:

因为主键值存在的意义就是这行记录的身份证号,只要意义达到即可,单一主键可以做到。

复合主键比较复杂,不建议使用

注意:

一张表的主键约束只能有一个,可以是表级约束也可以是列级约束,可以是单一主键,也可以是复合主键

主键值建议使用:

int

bigint

char

等类型

** 不建议使用:**

不建议使用 varchar来做主键。主键值一般都是数字,一般都是定长的

主键除了:单一主键和复合主键之外,还能分:

**自然主键:**主键值是一个自然数,和业务没关系。

**业务主键:**主键值和业务紧密关联,例如拿银行卡账号做主键值。这就是业务主键!

使用:

自然主键使用比较多,因为主键只要做到不重复就行,不需要有意义。

业务主键不好,因为主键一旦和业务挂钩,那么当业务发生变动的时候,

? 可能会影响到主键值,所以业务主键不建议使用。尽量使用自然主键。

自增机制:

mysql 中有一种机制,可以帮助我们自动维护一个主键值:

create table (表名)(

id int primary key auto_increment,

// auto_increment 表示自增,从1开始,以1递增

)

6.6、外键约束(foreign key,简称FK) * * * * *

外键约束的相关术语:

外键约束:一种约束(foreign key)

外键字段:该字段上添加了外键约束

外键值:外键字段当中的每一个值。

使用主键可以避免:

数据冗余,空间浪费

好处:

为了保证某个(s1字段)中的值都是(值1)和(值2),需要给(s1字段)添加外键约束。

那么:(s1字段)字段就是外键字段。(s1字段)字段中的每一个值都是外键值。

定义:

如果表中的某个字段为外键字段,那么该字段的值必须来源于参照的表的主键,如:s1表中的 deptno 值必须来源于 s2 表中的 deptno 字段值。

班级表与学生表联合:

// 班级表

create table t_classes(

classes_id int(3),

classes_name varchar(40),

constraint pk_classes_id primary key(classes_id)

);

在 t_student 表中加入外键约束

//学生表

create table t_student(

student_id int(10),

student_name varchar(20),

sex char(2),

birthday date,

email varchar(30),

classes_id int(3),

constraint student_id_pk primary key(student_id),

constraint fk_classes_id foreign key(classes_id) references t_classes(classes_id)

)

注意:

t_class是父表

t_student是子表

删除表的顺序

先删子,再删父。

创建表的顺序

先创建父,再创建子。

删除数据的顺序

先删子,再删父。

插入数据的顺序

先插入父,再插入子。

引用字段:

子表中的外键引用的父表中的某个字段,被引用的这个字段不一定是主键,但至少具有唯一性(unique) 约束

注意:

外键值可以是 null

7、存储引擎(了解)

7.1、什么是存储引擎

存储引擎是MySQL中特有的一个术语,其它数据库中没有。(Oracle中有,但是不叫这个名字)

存储引擎实际上是一个表存储/组织数据的方式。

不同的存储引擎,表存储数据的方式不同。

7.2、给表 添加//指定"存储引擎"

查看存储引擎:

show create table (表名);

例如:

mysql> show create table dept;

±------±----------------------------+

| Table | Create Table |

±------±----------------------------+

| dept | CREATE TABLE dept ( |

| DEPTNO int(2) NOT NULL, |

| DNAME varchar(14) DEFAULT NULL, |

| LOC varchar(13) DEFAULT NULL, |

| PRIMARY KEY (DEPTNO) |

|) ENGINE=InnoDB DEFAULT CHARSET=utf8 |

±------±----------------------------+

可以看见 最后小括号的 ")"的右边定义了存储引擎与字符编码方式等

手动添加存储引擎:

在建表的时候可以在最后小括号的")"的右边使用:

ENGINE来指定存储引擎。

CHARSET来指定这张表的字符编码方式。

例如:

create table (表名)(

id int primary key,

name varchar(255)

)engine=InnoDB default charset=gbk;

结论:

mysql默认的存储引擎是:InnoDB

mysql默认的字符编码方式是:utf8

7.3、查看支持的mysql存储引擎:

命令:

show engines \G

mysq存储引擎l:

mysql支持九大存储引擎\。版本不同支持情况不同。

7.3、关于mysql常用的存储引擎
7.3.1、MyISAM存储引擎:

特征:

它管理的表具有以下特征:

使用三个文件表示每个表:

格式文件 — 存储表结构的定义(mytable.frm)

数据文件 — 存储表行的内容(mytable.MYD)

索引文件 — 存储表上索引(mytable.MYI):索引是一本书的目录,缩小扫描范围,提高查询> 效率的一种机制。

可被转换为压缩、只读表来节省空间

注意:

对于一张表来说,只要是主键,或者加有unique约束的字段上会自动创建索引。

MyISAM存储引擎特点:

可被转换为压缩、只读表来节省空间

这是这种存储引擎的优势

MyISAM不支持事务机制,安全性低。

7.3.2、InnoDB存储引擎:

这是mysql默认的存储引擎,同时也是一个重量级的存储引擎。

InnoDB支持事务,支持数据库崩溃后自动恢复机制。

InnoDB存储引擎最主要的特点是:非常安全。

它管理的表具有下列主要特征:

– 每个 InnoDB 表在数据库目录中以.frm 格式文件表示

– InnoDB 表空间 tablespace 被用于存储表的内容(表空间是一个逻辑名称。表空间存储>数据>+索引。)

– 提供一组用来记录事务性活动的日志文件

– 用 COMMIT(提交)、SAVEPOINT 及ROLLBACK(回滚)支持事务处理

– 提供全 ACID 兼容

– 在 MySQL 服务器崩溃后提供自动恢复

– 多版本(MVCC)和行级锁定

– 支持外键及引用的完整性,包括级联删除和更新

InnoDB最大的特点就是支持事务:

以保证数据的安全。效率不是很高,并且也不能压缩,不能转换为只读,

不能很好的节省存储空间。

7.3.3、MEMORY存储引擎:

使用 MEMORY 存储引擎的表,其数据存储在内存中,且行的长度固定,

这两个特点使得 MEMORY 存储引擎非常快。

MEMORY 存储引擎管理的表具有下列特征:

– 在数据库目录内,每个表均以.frm 格式的文件表示。

– 表数据及索引被存储在内存中。(目的就是快,查询快!)

– 表级锁机制。

– 不能包含 TEXT 或 BLOB 字段。

MEMORY 存储引擎以前被称为HEAP 引擎:

MEMORY引擎优点:查询效率是最高的。不需要和硬盘交互。

MEMORY引擎缺点:不安全,关机之后数据消失。因为数据和索引都是在内存当中。

  • 13
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值