SQL语句之基础篇第四章

SQL语句之基础篇第四章

  • SQL语句基础
    • 1.UNION 和UNION ALL语句
    • 2.CREATE TBALE new_table as ....语句
    • 3.INSERT INTO SELECT 操作符

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值的数据时不包含重复数据
SQL语句之基础篇第四章_第1张图片

union all实例:

select id from test.student
union all
select id from test.teacher

此时,查询返回的id值数据是两张表的全部数据,同时,也包含重复的数据
SQL语句之基础篇第四章_第2张图片

2.CREATE TBALE new_table as …语句

作用:创建新表并同时将原有表的数据备份到新表中,可备份全部的数据,也可以选取对应列的数据进行备份

创建test表并将student 表中的数据全部备份到test表中:

create table test.test
as
select *
from test.student

备份成功后,查询test表数据:
SQL语句之基础篇第四章_第3张图片
student表数据:
SQL语句之基础篇第四章_第4张图片
创建test1表并将student表中的id和name列的数据备份到test1中

创建test1表并将student表中的id和name列的数据备份到test1中
create table test.test1
as
select id,name
from test.student

此时,查询test1表中数据,只存在id和name列的数据
SQL语句之基础篇第四章_第5张图片

**注释:我们在进行数据备份的时候,还可以在每个查询语句后面加上对应的条件进行筛选,选取自己需要的数据进行备份**

3.INSERT INTO SELECT 操作符

作用:INSERT INTO SELECT 语句从一个表复制数据,然后把数据插入到一个已存在的表中。目标表中任何已存在的行都不会受影响。

  1. 先将student表的数据结构复制到dome表
create table test.dome like test.student

复制成功后,dome表是不存在数据的-如下图:
SQL语句之基础篇第四章_第6张图片
2.再使用insert into select 语句将student表中的数据插入到dome表中

insert into test.dome
select *
from test.student

此时如下图所示,数据已经成功插入到dome表中了:
SQL语句之基础篇第四章_第7张图片

你可能感兴趣的:(SQL基础)