SQL语句基础
本篇主要是对数据的库中原有表进行数据的备份、复制以及将数据从原表中插入另一张表中的操作
备注:(本文实例使用的mysql数据库)若文中有存在问题的内容,请大家多多指教,欢迎大家打扰以及指导.........................
实例用以下两张表进行演示
student表结构如下图
teacher表结果如下图
两张表以id为主外键关系进行关联
1.UNION 和UNION ALL语句
作用:union 语句用于合并一个多或者多个select 语句返回的结果,并对返回结果进行去重显示出来。如果想显示全部的数据,则使用union all即可
备注:UNION 内部的每个 SELECT 语句必须拥有相同数量的列。列也必须拥有相似的数据类型。同时,每个 SELECT 语句中的列的顺序必须相同。
UNION 实例:
select id from test.student
union
select id from test.teacher
查询返回的id值的数据时不包含重复数据
union all实例:
select id from test.student
union all
select id from test.teacher
此时,查询返回的id值数据是两张表的全部数据,同时,也包含重复的数据
2.CREATE TBALE new_table as …语句
作用:创建新表并同时将原有表的数据备份到新表中,可备份全部的数据,也可以选取对应列的数据进行备份
创建test表并将student 表中的数据全部备份到test表中:
create table test.test
as
select *
from test.student
备份成功后,查询test表数据:
student表数据:
创建test1表并将student表中的id和name列的数据备份到test1中
创建test1表并将student表中的id和name列的数据备份到test1中
create table test.test1
as
select id,name
from test.student
此时,查询test1表中数据,只存在id和name列的数据
**注释:我们在进行数据备份的时候,还可以在每个查询语句后面加上对应的条件进行筛选,选取自己需要的数据进行备份**
3.INSERT INTO SELECT 操作符
作用:INSERT INTO SELECT 语句从一个表复制数据,然后把数据插入到一个已存在的表中。目标表中任何已存在的行都不会受影响。
- 先将student表的数据结构复制到dome表
create table test.dome like test.student
复制成功后,dome表是不存在数据的-如下图:
2.再使用insert into select 语句将student表中的数据插入到dome表中
insert into test.dome
select *
from test.student
此时如下图所示,数据已经成功插入到dome表中了: