SQL Server之SELECT INTO 和 INSERT INTO SELECT案例详解_MsSql

来源:脚本之家  责任编辑:小易  

做数据库开发的过程中难免会遇到有表数据备份的,而SELECT INTO……和INSERT INTO SELECT…… 这两种语句就是用来进行表数据复制,下面简单的介绍下:

1、INSERT INTO SELECT

语句格式:Insert Into Table2(column1,column2……) Select value1,value2,value3,value4 From Table1 或 Insert Into Table2 Select * From Table1

说明:这种方式的表复制必须要求Table2是事先创建好的

例:

--1.创建表
create TABLE Table1
(
    a varchar(10),
    b varchar(10),
    c varchar(10)
) ;

create TABLE Table2
(
    a varchar(10),
    c varchar(10),
    d varchar(10)
);
commit;
--2.创建测试数据
Insert into Table1 values('赵','asds','90');
Insert into Table1 values('钱','asds','100');
Insert into Table1 values('孙','asds','80');
Insert into Table1 values('李','asds',null);
commit;
--3.复制table1数据到table2中
Insert into Table2(a, c, d) select a,b,c from Table1;
commit;
--或,此种方式必须要求table2和table1的列数相等,而且类型兼容
Insert into Table2 select * from table1;
commit;

以上这些sql在oracle和MS SqlServer中的语法是一样的,可以通用.

2、SELECT INTO……

这种方式的语句可以在Table2不存在的时候进行表数据复制,编译器会根据Table1的表结构自动创建Table2,Table2和Table1的结构基本上是一致的,但是如果已经存在Table2,则编译器会报错.

这种方式的语句在Oracle中和MS SqlServer中是有点差别的,,如下:

语句格式:

Oracle:Create Table2 as Select column1,column2……From Table1 或 Create Table2 as Select * From Table1

MS SqlServer:Select column1,column2…… into Table2 From Table1 或 Select * into Table2 From Table1

例:

--Oracle
--1.创建表
create TABLE Table1
(
    a varchar(10),
    b varchar(10),
    c varchar(10)
) ;

commit;
--2.创建测试数据
Insert into Table1 values('赵','asds','90');
Insert into Table1 values('钱','asds','100');
Insert into Table1 values('孙','asds','80');
Insert into Table1 values('李','asds',null);
commit;
--3.复制table1数据到table2中
Create Table Table2 as select a,b,c From table1;
Commit;
--或(这两种方式的sql只能应用一次)
Create table table2 as select * From Table1;
Commit;
--删除表
drop table table1;
drop table table2;
commit;
--MS SqlServer
--1.创建表
create TABLE Table1
(
    a varchar(10),
    b varchar(10),
    c varchar(10)
) ;

commit;
--2.创建测试数据
Insert into Table1 values('赵','asds','90');
Insert into Table1 values('钱','asds','100');
Insert into Table1 values('孙','asds','80');
Insert into Table1 values('李','asds',null);
commit;
--3.复制table1数据到table2中
Select a,b,c into Table2 From table1;
Commit;
--或(这两种方式的sql只能应用一次)
Select * into table2 From Table1;
Commit;
--删除表
drop table table1;
drop table table2;
commit;

到此这篇关于SQL Server之SELECT INTO 和 INSERT INTO SELECT案例详解的文章就介绍到这了,更多相关SQL Server之SELECT INTO 和 INSERT INTO SELECT内容请搜索真格学网以前的文章或继续浏览下面的相关文章希望大家以后多多支持真格学网!

您可能感兴趣的文章:sqlserver存储过程中SELECT 与 SET 对变量赋值的区别SQLServer中SELECT语句的执行顺序SQLServer之常用函数总结详解SqlServer数据库远程连接案例教程

  • 本文相关:
  • 解决sql server的“此数据库没有有效所有者”问题
  • sqlserver 数据库开发顶级技巧
  • 使用forfiles命令来删除sqlserver备份的批处理
  • sqlserver查询数据类型为ntext是空或null值的方法
  • sql2005 hashbytes 加密函数
  • blazor server 应用程序中进行 http 请求
  • sql server里书签查找的性能伤害
  • sqlserver2000+ 身份证合法校验函数的示例代码
  • bcp 大容量数据导入导出工具使用步骤
  • 使用sql语句去掉重复的记录【两种方法】
  • 怎么删除SQL server数据库
  • 什么事SQL Server代理服务?其作用是什么
  • sqlserver与oracle的区别
  • SQL Server 2008安装错误,提示提供有效的账户和密码,都填上...
  • erver和mysql区别大么
  • sqlserver客户端连接端口不是1433的服务器,该怎么连接
  • 在win7下启动和停止sqlserver服务的命令
  • sql server 2008 插入数据 ?
  • SQL Server的作用是什么 干什么用的 为什么会用到?
  • sqlserver的datetime查询
  • 求一个SQL Server游标应用实例?
  • 在sql server中如何将获取日期和时间值赋值给一个变量
  • Mysql与sql server的区别
  • SQL Server 服务管理器 这个东西是干什么用的 可以关掉或者删...
  • sql server如何添加约束
  • SQL Server 7.0和SQL Server 2000哪个新?
  • sqlserver怎么建临时表?
  • SQL server 数据库的版本为661,无法打开,此服务器只支持655...
  • SQLServer2000中 如何用sql脚本还原数据库
  • 怎样远程连接SQL Server2000数据库
  • 网站首页网页制作脚本下载服务器操作系统网站运营平面设计媒体动画电脑基础硬件教程网络安全mssqlmysqlmariadboracledb2mssql2008mssql2005sqlitepostgresqlmongodbredisaccess数据库文摘数据库其它首页sqlserver存储过程中select 与 set 对变量赋值的区别sqlserver中select语句的执行顺序sqlserver之常用函数总结详解sqlserver数据库远程连接案例教程解决sql server的“此数据库没有有效所有者”问题sqlserver 数据库开发顶级技巧使用forfiles命令来删除sqlserver备份的批处理sqlserver查询数据类型为ntext是空或null值的方法sql2005 hashbytes 加密函数blazor server 应用程序中进行 http 请求sql server里书签查找的性能伤害sqlserver2000+ 身份证合法校验函数的示例代码bcp 大容量数据导入导出工具使用步骤sql server 2012 安装图解教程(附sql server数据库入门学习总结microsoft sql server 2012 数据win7系统安装sqlserver2000的详细sql重复记录查询的几种方法sqlserver中distinct的用法(不重sql server错误代码大全及解释(sql-order by 多字段排序(升序、sql将一个表中的数据插入到另一个用sql语句添加删除修改字段、一些zabbix监控sql server服务状态的方法详解关于sql 存储过程入门基础(基础知识)在数据库中自动生成编号的实现方法分享mysql8.0.17安装教程【推荐】sqlserver全文目录全文索引的使用方法和区深入sql cursor基本用法的详细介绍sqlserver2019配置端口号的实现sql server2012在开发中的一些新特性sql语句的并集union 交集join(内连接,外sql存储过程几个简单例子
    免责声明 - 关于我们 - 联系我们 - 广告联系 - 友情链接 - 帮助中心 - 频道导航
    Copyright © 2017 www.zgxue.com All Rights Reserved