insert values insert select insert exec select into bulk insert insert values是最常用的一种插入数据的方式,基本语法如下,表名之后可以指定目标列的名称,这种显式的指定目标列的名称是可选的,但是这种做法的好处是对语句的列值列名之间的关联关系进
insert valuesinsert selectinsert execselect intobulk insertinsert values是最常用的一种插入数据的方式,基本语法如下,表名之后可以指定目标列的名称,这种显式的指定目标列的名称是可选的,但是这种做法的好处是对语句的列值列名之间的关联关系进行控制,而不必单纯的依赖定义表时
各个列出现的顺序
insert into dbo.dimdate ( datakey , year , qu , qucn , month , monthcn , ten , tencn , week , weekday , day , date )values ( 0 , -- datakey - int 0 , -- year - int 0 , -- qu - int '' , -- qucn - varchar(20) 0 , -- month - int '' , -- monthcn - varchar(20) 0 , -- ten - int '' , -- tencn - varchar(20) 0 , -- week - int '' , -- weekday - varchar(20) 0 , -- day - int '2014-09-23 13:34:16' -- date - datetime )
确定列值的优先级顺序:给定的值》默认值》null
sql2008增强了values功能,允许在一条语句中指定由逗号隔开的多条记录
insert into dbo.table_1 ( id ) values ( 0 ),( 1 ),( 2 )
使用values构建虚拟表
select * from (values ( 0 ),( 1 ),( 2 )) as a(id)
insert select
insert select 将一组由select查询返回的结果行插入到目标表中(目标表是已经存在的表,这一点和select into有区别)
insert into dbo.table_1 select * from dbo.table_2
insert exec
insert exec 语句可以把存储过程或动态sql批处理返回的结果集插入到目标表
select into
select into的作用是创建一个目标表,并用返回的结果集填充它,不能用这个语句向已经存在的表中插入数据,
当指定的目标表是临时表时自动创建一个临时表,指定为用户表时创建一个用户表,
select into 会复制来源表的基本结构(包括列名、数据类型、是否允许null以及identity属性),不会复制的三样东西(约束、索引、触发器)
select into的另一个优点:如果数据库的属性没有设置成完成恢复模式,select into 就会按照最小日志记录模式来执行操作
bulk insert
这种方式用的比较少,用于将文件中的数据导入一个已经存在的表
示例本例从指定的数据文件中导入订单详细信息,该文件使用竖杠 (|) 字符作为字段终止符,使用 |/n 作为行终止符。
bulk insert northwind.dbo.[order details] from 'f:/orders/lineitem.tbl' with ( fieldterminator = '|', rowterminator = '|/n' )