【数据库三】insert插⼊多条数据,对表的操作,约束,存储引擎,事务数据库三
⼀、insert语句可以⼀次插⼊多条记录
mysql>desc t_user;
+-------------+-------------+------+-----+---------+-------+
| Field      |Type|Null|Key|Default| Extra |
+-------------+-------------+------+-----+---------+-------+
| id          |int(11)| YES  ||NULL||
| name        |varchar(32)| YES  ||NULL||
| birth      |date| YES  ||NULL||
| create_time |datetime| YES  ||NULL||
+-------------+-------------+------+-----+---------+-------+
⼀次可以插⼊多条记录:
insert into t_user(id,name,birth,create_time) values
(1,‘zs’,‘1980-10-11’,now()),
(2,‘lisi’,‘1981-10-11’,now()),
(3,‘wangwu’,‘1982-10-11’,now());
语法:insert into t_user(字段名1,字段名2) values(),(),(),();
mysql>select*from t_user;
+------+--------+------------+---------------------+
| id  | name  | birth      | create_time        |
+------+--------+------------+---------------------+
|1| zs    |1980-10-11|2020-03-1909:37:01|
|2| lisi  |1981-10-11|2020-03-1909:37:01|
|3| wangwu |1982-10-11|2020-03-1909:37:01|
+------+--------+------------+---------------------+
⼆、对表的操作
1.快速创建表
mysql>create table emp2 as select*from emp;
原理:
将⼀个查询结果当做⼀张表新建
这个可以完成表的快速复制
表创建出来,同时表中的数据也存在了
create table mytable as select empno,ename from emp where job ='MANAGER';
2.将查询结果插⼊到⼀张表当中
create table dept_bak as select*from dept;
mysql>select*from dept_bak;
+--------+------------+----------+
| DEPTNO | DNAME      | LOC      |
+--------+------------+----------+
|10| ACCOUNTING | NEW YORK |
|20| RESEARCH  | DALLAS  |
|30| SALES      | CHICAGO  |
|40| OPERATIONS | BOSTON  |
+--------+------------+----------+
下⾯这种⽅法⽐较少⽤
insert into dept_bak select*from dept;//很少⽤!
mysql>select*from dept_bak;
+--------+------------+----------+
| DEPTNO | DNAME      | LOC      |
+--------+------------+----------+
|10| ACCOUNTING | NEW YORK |
|20| RESEARCH  | DALLAS  |
|30| SALES      | CHICAGO  |
|40| OPERATIONS | BOSTON  |
|10| ACCOUNTING | NEW YORK |
|20| RESEARCH  | DALLAS  |
|30| SALES      | CHICAGO  |
|40| OPERATIONS | BOSTON  |
+--------+------------+----------+
3.快速删除表中的数据-truncate
删除dept_bak表中的数据
delete from dept_bak;//这种删除数据的⽅式⽐较慢。
mysql>select*from dept_bak;
Empty set(0.00 sec)
delete语句删除数据的原理(delete属于DML语句)
表中的数据被删除了,但是这个数据在硬盘上的真实存储空间不会被释放
这种删除缺点是:删除效率⽐较低。
这种删除优点是:⽀持回滚,后悔了可以再恢复数据
truncate语句删除数据的原理
这种删除效率⽐较⾼,表被⼀次截断,物理删除。
这种删除缺点:不⽀持回滚。
这种删除优点:快速。
⽤法:truncate table dept_bak; (这种操作属于DDL操作。)
如果⼤表⾮常⼤,上亿条记录
删除的时候,使⽤delete,也许需要执⾏1个⼩时才能删除完!效率较低。
可以选择使⽤truncate删除表中的数据。只需要不到1秒钟的时间就删除结束。效率较⾼。      但是使⽤truncate之前,必须仔细询问客户是否真的要删除,并警告删除之后不可恢复!
truncate是删除表中的数据,表还在!
删除表操作
drop table 表名; // 这不是删除表中的数据,这是把表删除。
4.对表结构的增删改
什么是对表结构的修改?
添加⼀个字段,删除⼀个字段,修改⼀个字段
对表结构的修改需要使⽤:alter
属于DDL语句
DDL包括:create drop alter
第⼀:在实际的开发中,需求⼀旦确定之后,表⼀旦设计好之后,很少的
进⾏表结构的修改。因为开发进⾏中的时候,修改表结构,成本⽐较⾼。
修改表的结构,对应的java代码就需要进⾏⼤量的修改。成本是⽐较⾼的。
这个责任应该由设计⼈员来承担!
第⼆:由于修改表结构的操作很少,所以我们不需要掌握,如果有⼀天
真的要修改表结构,你可以使⽤⼯具
修改表结构的操作是不需要写到java程序中的。实际上也不是java程序员的范畴。
三、约束
1、什么是约束?
约束对应的英语单词:constraint
在创建表的时候,我们可以给表中的字段加上⼀些约束,来保证这个表中数据的
完整性、有效性
约束的作⽤就是为了保证:表中的数据有效!!防⽌出现没有⽤的数据或者不存在的数据2、约束包括哪些?
约束分类:
⾮空约束:not null
唯⼀性约束: unique
主键约束: primary key (简称PK)
外键约束:foreign key(简称FK)
检查约束:check(mysql不⽀持,oracle⽀持)
我们这⾥重点学习四个约束:
not null
unique
primary key
foreign key
3、⾮空约束:not null
⾮空约束not null约束的字段不能为NULL。mysql中delete语句
drop table if exists t_vip;
create table t_vip(
id int,
name varchar(255)not null// not null只有列级约束,没有表级约束!
);
insert into t_vip(id,name)values(1,'zhangsan');
insert into t_vip(id,name)values(2,'lisi');
insert into t_vip(id)values(3);
ERROR 1364(HY000): Field 'name' doesn't have a default value
4、唯⼀性约束: unique
唯⼀性约束unique约束的字段不能重复,但是可以为NULL。
drop table if exists t_vip;
create table t_vip(
id int,
name varchar(255)unique,
email varchar(255)
);
insert into t_vip(id,name,email)values(1,'zhangsan','zhangsan@123');
insert into t_vip(id,name,email)values(2,'lisi','lisi@123');
insert into t_vip(id,name,email)values(3,'wangwu','wangwu@123');
select*from t_vip;
insert into t_vip(id,name,email)values(4,'wangwu','wangwu@sina');
ERROR 1062(23000): Duplicate entry 'wangwu'for key'name'
insert into t_vip(id)values(4);
insert into t_vip(id)values(5);
+------+----------+------------------+
| id  | name    | email            |
+------+----------+------------------+
|1| zhangsan | zhangsan@123|
|2| lisi    | lisi@123|
|3| wangwu  | wangwu@123|
|4|NULL|NULL|
|5|NULL|NULL|
+------+----------+------------------+
name字段虽然被unique约束了,但是可以为NULL。
新需求:name和email两个字段联合起来具有唯⼀性
drop table if exists t_vip;
create table t_vip(
id int,
name varchar(255)unique,// 约束直接添加到列后⾯的,叫做列级约束。
email varchar(255)unique
);
这张表这样创建是不符合我以上“新需求”的。
这样创建表⽰:name具有唯⼀性,email具有唯⼀性。各⾃唯⼀。
以下这样的数据是符合我“新需求”的。
但如果采⽤以上⽅式创建表的话,肯定创建失败,因为’zhangsan’和’zhangsan’重复了。      insert into t_vip(id,name,email) values(1,‘zhangsan’,‘zhangsan@123’);
insert into t_vip(id,name,email) values(2,‘zhangsan’,‘zhangsan@sina’);
怎么创建这样的表,才能符合新需求呢?
drop table if exists t_vip;
create table t_vip(
id int,
name varchar(255),
email varchar(255),
unique(name,email)// 约束没有添加在列的后⾯,这种约束被称为表级约束。
);
insert into t_vip(id,name,email)values(1,'zhangsan','zhangsan@123');
insert into t_vip(id,name,email)values(2,'zhangsan','zhangsan@sina');
select*from t_vip;
name和email两个字段联合起来唯⼀
insert into t_vip(id,name,email)values(3,'zhangsan','zhangsan@sina');
ERROR 1062(23000): Duplicate entry 'zhangsan-zhangsan@sina'for key'name'
- 什么时候使⽤表级约束呢?
需要给多个字段联合起来添加某⼀个约束的时候,需要使⽤表级约束。
- unique 和not null可以联合吗?
drop table if exists t_vip;
create table t_vip(
id int,
name varchar(255)not null unique
);
mysql>desc t_vip;
+-------+--------------+------+-----+---------+-------+
| Field |Type|Null|Key|Default| Extra |
+-------+--------------+------+-----+---------+-------+
| id    |int(11)| YES  ||NULL||
| name  |varchar(255)|NO| PRI |NULL||
+-------+--------------+------+-----+---------+-------+
在mysql当中,如果⼀个字段同时被not null和unique约束的话,
该字段⾃动变成主键字段。(注意:oracle中不⼀样!)
insert into t_vip(id,name)values(1,'zhangsan');
insert into t_vip(id,name)values(2,'zhangsan');//错误了:name不能重复
insert into t_vip(id)values(2);//错误了:name不能为NULL。
5、主键约束(primary key,简称PK)⾮常重要
主键约束的相关术语
主键约束:就是⼀种约束。
主键字段:该字段上添加了主键约束,这样的字段叫做:主键字段
主键值:主键字段中的每⼀个值都叫做:主键值。
什么是主键
主键值是每⼀⾏记录的唯⼀标识。
主键值是每⼀⾏记录的⾝份证号
记住:任何⼀张表都应该有主键,没有主键,表⽆效!!
主键的特征:not null + unique(主键值不能是NULL,同时也不能重复!)单⼀主键的创建:
怎么给⼀张表添加主键约束呢?
drop table if exists t_vip;
// 1个字段做主键,叫做:单⼀主键
create table t_vip(
id int primary key,//列级约束
name varchar(255)
);
insert into t_vip(id,name)values(1,'zhangsan');
insert into t_vip(id,name)values(2,'lisi');
//错误:不能重复
insert into t_vip(id,name)values(2,'wangwu');
ERROR 1062(23000): Duplicate entry '2'for key'PRIMARY'
//错误:不能为NULL
insert into t_vip(name)values('zhaoliu');
ERROR 1364(HY000): Field 'id' doesn't have a default value
可以这样添加主键,使⽤表级约束

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。