SQL 插入语句汇总
INSERT VALUES
插入一行或多行到目标表中
-- single row
INSERT INTO Sales.MyOrders(custid, empid, orderdate, shipcountry, freight)
VALUES(2, 19, '', N'USA', 30.00); -- relying on defaults
INSERT INTO Sales.MyOrders(custid, empid, shipcountry, freight)
VALUES(3, 11, N'USA', 10.00); INSERT INTO Sales.MyOrders(custid, empid, orderdate, shipcountry, freight)
VALUES(3, 17, DEFAULT, N'USA', 30.00); -- multiple rows
INSERT INTO Sales.MyOrders(custid, empid, orderdate, shipcountry, freight) VALUES
(2, 11, '', N'USA', 50.00),
(5, 13, '', N'USA', 40.00),
(7, 17, '', N'USA', 45.00);
注:如果要更新自增字段需要把IDENTITY_INSERT选项开启,用完后记得关闭
SET IDENTITY_INSERT <table> ON;
INSERT SELECT
把select 语句的查询结果插入到表中,这个中方法要比上面的INSERT VALUES 效率高
SET IDENTITY_INSERT Sales.MyOrders ON; INSERT INTO Sales.MyOrders(orderid, custid, empid, orderdate, shipcountry, freight)
SELECT orderid, custid, empid, orderdate, shipcountry, freight
FROM Sales.Orders
WHERE shipcountry = N'Norway'; SET IDENTITY_INSERT Sales.MyOrders OFF;
INSERT EXEC
该语句可以让你把动态语句或者存储过程的结果插入表格。
-- create procedure
IF OBJECT_ID(N'Sales.OrdersForCountry', N'P') IS NOT NULL
DROP PROC Sales.OrdersForCountry;
GO CREATE PROC Sales.OrdersForCountry
@country AS NVARCHAR(15)
AS SELECT orderid, custid, empid, orderdate, shipcountry, freight
FROM Sales.Orders
WHERE shipcountry = @country;
GO -- insert the result of the procedure
SET IDENTITY_INSERT Sales.MyOrders ON; INSERT INTO Sales.MyOrders(orderid, custid, empid, orderdate, shipcountry, freight)
EXEC Sales.OrdersForCountry
@country = N'Portugal'; SET IDENTITY_INSERT Sales.MyOrders OFF;
对于动态SQL,或者类似DBCC这种非常规的SQL语句,都可以通过这种方式来保存结果集。
CREATE TABLE test_dbcc
(
TraceFlag VARCHAR(100) ,
Status TINYINT ,
Global TINYINT ,
Session TINYINT
) INSERT INTO test_dbcc
EXEC ( 'DBCC TRACESTATUS'
)
注:不能嵌套使用insert exec语句 ,可以用以下方式变动(这里直接拷贝参考文章中的内容。我没试验过)
1.首先到打开服务器选项Ad Hoc Distributed Queries
exec sp_configure 'show advanced options',1
RECONFIGURE
GO
exec sp_configure 'Ad Hoc Distributed Queries',1
RECONFIGURE
GO
2. 通过OPENROWSET连接到本机,运行存储过程,取得结果集
--使用Windows认证
SELECT *
INTO #JobInfo_S1
FROM OPENROWSET('sqloledb', 'server=(local);trusted_connection=yes',
'exec msdb.dbo.sp_help_job') --使用SQL Server认证
SELECT *
INTO #JobInfo_S2
FROM OPENROWSET('SQLOLEDB', '127.0.0.1'; 'sa'; 'sa_password',
'exec msdb.dbo.sp_help_job')
这样的写法,既免去了手动建表的麻烦,也可以避免insert exec 无法嵌套的问题。几乎所有SQL语句都可以使用。
--dbcc不能直接运行
SELECT a.*
INTO #t
FROM OPENROWSET('SQLOLEDB', '127.0.0.1'; 'sa'; 'sa_password',
'dbcc log(''master'',3)') AS a --可以变通一下
SELECT a.*
INTO #t
FROM OPENROWSET('SQLOLEDB', '127.0.0.1'; 'sa'; 'sa_password',
'exec(''DBCC LOG(''''master'''',3)'')') AS a
SELECT INTO
该语句不需要我们事先建立目标表,而是直接拷贝数据源或者查询结果数据定义:比如列名,类型,是否为空,自增等来建立目标表。
-- simple SELECT INTO
IF OBJECT_ID(N'Sales.MyOrders', N'U') IS NOT NULL DROP TABLE Sales.MyOrders; SELECT orderid, custid, orderdate, shipcountry, freight
INTO Sales.MyOrders
FROM Sales.Orders
WHERE shipcountry = N'Norway';
通过以下存储可以查看查询返回字段的结构,注意name,system_type_name,is_nullable.
EXEC sp_describe_first_result_set N'SELECT * FROM Sales.Customers;';
利用select into 生成一个空表
select * into #temp from sysobjects where 1=2
实际插入案例
1) 学生表插入
CREATE PROCEDURE [dbo].[Students_Insert]
(
@ID INT ,
@LASTNAME VARCHAR(50) ,
@FIRSTNAME VARCHAR(50) ,
@STATE VARCHAR(50) ,
@PHONE VARCHAR(50) ,
@EMAIL VARCHAR(50) ,
@GRADYEAR INT ,
@GPA DECIMAL(20, 10) ,
@PROGRAM VARCHAR(50) ,
@NEWSLETTER BIT
)
AS
BEGIN
--Check to make sure the ID does not already exist
--If it does, return error
DECLARE @existing AS INT = 0
SELECT @existing = COUNT(ID)
FROM Students
WHERE ID = @ID IF @existing > 0
BEGIN
RAISERROR ('ID already exists', 1, 1)
RETURN 0
END
--Format GPA as 2 decimal places
DECLARE @TwoDecimalGPA AS DECIMAL(3, 2)
SELECT @TwoDecimalGPA = CAST(@GPA AS NUMERIC(3, 2))
--Make sure GPA is within range
IF ( ( @TwoDecimalGPA > 4 )
OR ( @TwoDecimalGPA < 0 )
)
BEGIN
RAISERROR ('GPA value is invalid', 1, 1)
RETURN 0
END
--Attempt insert
INSERT INTO [dbo].[Students]
( [ID] ,
[LASTNAME] ,
[FIRSTNAME] ,
[STATE] ,
[PHONE] ,
[EMAIL] ,
[GRADYEAR] ,
[GPA] ,
[PROGRAM] ,
[NEWSLETTER]
)
VALUES ( @ID ,
@LASTNAME ,
@FIRSTNAME ,
@STATE ,
@PHONE ,
@EMAIL ,
@GRADYEAR ,
@TwoDecimalGPA ,
@PROGRAM ,
@NEWSLETTER
)
--check to see if insert occured
--and return status
IF @@ROWCOUNT = 1
RETURN 1
ELSE
RETURN 0
END
GO
2) 循环插入
-----SQL SERVER中直接循环写入数据-----
DECLARE @i INT
SET @i = 1
WHILE @i < 30
BEGIN
INSERT INTO test
( userid )
VALUES ( @i )
SET @i = @i + 1
END
--案例:
--有如下表,要求就裱中所有沒有及格的成績,在每次增長0.1的基礎上,使他們剛好及格:
-- Name score
-- Zhangshan 80
-- Lishi 59
-- Wangwu 50
-- Songquan 69 WHILE ( ( SELECT MIN(score)
FROM tb_table
) < 60 )
BEGIN
UPDATE tb_table
SET score = score * 1.01
WHERE score < 60
IF ( SELECT MIN(score)
FROM tb_table
) > 60
BREAK
ELSE
CONTINUE
END
参考文档
The Data Loading Performance Guide http://msdn.microsoft.com/en-us/library/dd425070.aspx.
01. 把存储过程结果集SELECT INTO到临时表 http://www.cnblogs.com/seusoftware/p/3222564.html
SQL 插入语句汇总的更多相关文章
- 快速将一个表的数据生成SQL插入语句
将一个表中的数据生成SQL插入语句,方便系统快速初始化,在数据库中执行创建以下过程就可以了. ) Drop Procedure GenerateData go CREATE PROCEDURE Gen ...
- [lua, mysql] 将多条记录数据组合成一条sql插入语句(for mysql)
-- 演示将多条记录数据组合成一条sql插入语句(for mysql) function getTpl0(tname) -- 获取表各个字段 local t = { tpl_pack = {" ...
- 小程序实现sql插入语句转换成Laravel迁移语句
sql的插入语句长这样: INSERT INTO `media` (`MediaID`, `type`, `filename`, `title`) VALUES (1, 'word', 'word1. ...
- 如何通过注解Bean类来封装SQL插入语句
整体思路是酱紫的: 给bean上注解说明该bean对应着数据库中哪张表,给每个bean的属性都注解说明各自对应着这张表的哪个字段. 通过类反射获取表名,通过逐个反射每个属性的getter方法,获取注解 ...
- 比较两个文件不同以及生成SQL插入语句
Tips 做一个终身学习的人! 日拱一卒,功不唐捐. 今天有个小小的需求,具体需求是这样的: 有两个文本文件,每个文件都有一些字符串文本: 比较第一个文件中,在第二个文件中,不存在的字符串文本: 把这 ...
- sql常用语句汇总
--创建数据库 USE yuju CREATE database YuJu on primary ( name='YuJu', filename='B:\ceshi数据库\YuJu.mdf', max ...
- SQL基本语句汇总
语句:CREATE TABLE 作用:创建表格 格式:CREATE TABLE tableName (columnName1 columnDataType1, columnName2 columnDa ...
- sql插入语句笔记
使用INSERT插入数据行 [一次插入一行数据] 全写: INSERT INTO renshi (name, sex, age ,tel) VALUES ('胡大姐','女','35','13 ...
- 最新省市区数据,sql插入语句
--省数据 insert into Province (ProvinceName) values('北京市'); insert into Province (ProvinceName) value ...
随机推荐
- 《Pointers On C》读书笔记(第一章 快速上手)
1.C语言是一种自由格式的程序设计语言,没有规则要求我们必须如何书写语句.然而,如果我们在编写程序时能够遵守一些约定还是非常值得的,它可以使代码更加容易阅读和修改.另外,预处理命令有较为严格的规则. ...
- linux服务器在运行210天左右宕机
减小字体 增大字体 作者:错新网 来源:www.cuoxin.com 发布时间:2014-2-25 19:21:32 错新网讯 最近几天,一批linux线上的服务器接连宕机,当时以为是硬件问题 ...
- c++ - fcgio.cpp:50: error: 'EOF' was not declared in this scope - Stack Overflow
c++ - fcgio.cpp:50: error: 'EOF' was not declared in this scope - Stack Overflow fcgio.cpp:50: error ...
- Android系统的“程序异常退出”[转]
在应用运行过程中,有很多异常可能会发生,而我们希望在异常发生的时候第一时间的保存现场. 如何处理未捕获的异常呢? 首先我们要实现一个接口 java.lang.Thread.UncaughtExcep ...
- Android 匿名共享内存C接口分析
在Android 匿名共享内存驱动源码分析中详细分析了匿名共享内存在Linux内核空间的实现,虽然内核空间实现了匿名共享内存,但仍然需要在用户空间为用户使用匿名共享内存提供访问接口.Android系统 ...
- SQL修炼道路上必看的书籍
1 SQL应用重构 9787111263586 2 SQL 必知必会(第3版) 9787115162601 3 SQL Server 2005高级程序设计 9787115170798 4 SQL 解惑 ...
- 判断联网wifi
UIApplication *app = [UIApplication sharedApplication]; NSArray *children = [[[app valueForKeyPath:@ ...
- Unity3d 通过协程来实现文件的全部加载后执行
相信大家会经常遇到在游戏中需要WWW从本地或者服务器上获取数据,而我们通常容易会犯下面这种个错误:当数据较少或者网速较好时程序运行正常.而当数据较大或者网速不好时程序会出错误.比如卡住. 所以我们要使 ...
- win7程序关闭后弹出 程序兼容性助手 这个程序可能安装不正确 如果此程序没有正确安装,处理方式
用WTL编写的程序,编译成release后,在win7上关闭后,弹出这个对话框 处理方法: 将这个xml文件命名成 xxx.exe.manifest,保存到指定目录下 <?xml version ...
- maven build脚本笔记
如果 code 只存在src/java/main 路径下,直接install就好,不必写<build> 资源文件:edu-common-config <build> <f ...