insert 语法

Insert可以使一个表新增一个或多个记录:



INSERT INTO:新增一个记录。

INSERT INTO…SELECT:新增多个记录。


一、INSERT INTO

新增一个记录的INSERT INTO语法如下:

INSERT INTO 表 [(字段1[,字段2[, ...]])]
VALUES (值1[,值2[, ...])

新增的记录,将依照指定字段排列的顺序插入对应的值,譬如值1将被插入至字段1,值2将被插入至字段2,依此类推。

若未指定 (字段1[,字段2[, ...]]) ,将依照表所定义的字段排列的顺序插入对应的值,在VALUES 子句必须包含表中的每一字段值。

值间须使用逗点分隔,文字字段须使用单用引号 ('值') 括起来。

二、Insert Into...Select

若要新增多个记录,可以使用INSERT INTO…SELECT,语法如下:

INSERT INTO 表 [IN 外部资料库] [(字段1[,字段2[, ...]])]
SELECT [表.]字段1[, 字段2[, ...]
FROM 表

如果表包含一个主索引,须确定新增到主索引字段的值是唯一的且不可为Null值。

原表的字段为自动编号类型时,如果您要将新增记录重新编号,就不要在查询之中包含自动编号字段。若要保持原字段中的值,则将自动编号加在查询之中。

INSERT INTO将所新增的记录加入原有的表之中。若要建立一个新的表,可以使用 SELECT... INTO 的语句。

------------------------------

Insert是T-sql中常用语句,Insert INTO table(field1,field2,...) values(value1,value2,...)这种形式的在应用程序开发中必不可少。但我们在开发、测试过程中,经常会遇到需要表复制的情况,如将一个table1的数据的部分字段复制到table2中,或者将整个table1复制到table2中,这时候我们就要使用SELECT INTO 和 INSERT INTO SELECT 表复制语句了。

1.INSERT INTO SELECT语句

语句形式为:Insert into Table2(field1,field2,...) select value1,value2,... from Table1

要求目标表Table2必须存在,由于目标表Table2已经存在,所以我们除了插入源表Table1的字段外,还可以插入常量。示例如下:

INSERT INTO SELECT语句复制表数据
--1.创建测试表
create TABLE Table1
(
a
varchar(10),
b
varchar(10),
c
varchar(10),
CONSTRAINT [PK_Table1] PRIMARY KEY CLUSTERED
(
a
ASC
)
)
ON [PRIMARY]

create TABLE Table2
(
a
varchar(10),
c
varchar(10),
d
int,
CONSTRAINT [PK_Table2] PRIMARY KEY CLUSTERED
(
a
ASC
)
)
ON [PRIMARY]
GO
--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)
GO
select * from Table2

--3.INSERT INTO SELECT语句复制表数据
Insert into Table2(a, c, d) select a,c,5 from Table1
GO

--4.显示更新后的结果
select * from Table2
GO
--5.删除测试表
drop TABLE Table1
drop TABLE Table2


2.SELECT INTO FROM语句

语句形式为:SELECT vale1, value2 into Table2 from Table1

要求目标表Table2不存在,因为在插入时会自动创建表Table2,并将Table1中指定字段数据复制到Table2中。示例如下:

SELECT INTO FROM创建表并复制表数据
--1.创建测试表
create TABLE Table1
(
a
varchar(10),
b
varchar(10),
c
varchar(10),
CONSTRAINT [PK_Table1] PRIMARY KEY CLUSTERED
(
a
ASC
)
)
ON [PRIMARY]
GO

--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)
GO

--3.SELECT INTO FROM语句创建表Table2并复制数据
select a,c INTO Table2 from Table1
GO

--4.显示更新后的结果
select * from Table2
GO
--5.删除测试表
drop TABLE Table1
drop TABLE Table2
--------------------------------------------
select into 和 insert into select 两种表复制语句之间的差别

select * into destTbl from srcTbl

insert into destTbl(fld1, fld2) select fld1, 5 from srcTbl

以上两句都是将 srcTbl 的数据插入到 destTbl,但两句又有区别的。

第一句(select into from)要求目标表(destTbl)不存在,因为在插入时会自动创建。

第二句(insert into select from)要求目标表(destTbl)存在,由于目标表已经存在,所以我们除了插入源表(srcTbl)的字段外,还可以插入常量,如例中的:5。
如下例子:
create table t1
(
a char(2) null,
b char(2) null
)
insert into t1
select 'a1','b1'
union
select 'a2','b2'
select * from t1
<!--StartFragment -->
create table t2
(
c char(2) null,
d char(2) null
)
insert into t2
select 'c1','d1'
union
select 'c2','d2'
union
select a,b from t1
select * from t2
<!--StartFragment -->
create table t3
(
ac char(2) null,
bd char(2) null
)

insert into t3
select a,b from t1
union
select c,d from t2
select * from t3
<!--StartFragment -->
create table t4
(ac1 char(2) null,
bd1 char(2) null
)

insert into t4
select a,b from t1
union all
select c,d from t2
select * from t4
<!--StartFragment -->
<think>我们正在处理用户查询:"我想查询JS宏insert语法的相关信息 请问JavaScript宏insert语法介绍" 根据用户提供的引用,特别是引用[1]和引用[2]中提到了JavaScript(包括ES6)中的insert相关语法。 引用[1]展示了一个使用箭头函数实现的链式调用插入方法: let insert = (value) => ({into: (array) => ({after: (afterValue) => { ... }})}); 这个函数允许链式调用:insert(2).into([1,3]).after(1) 将2插入到数组[1,3]中1的后面,得到[1,2,3]。 引用[2]则展示了一个录制宏生成的代码,其中使用了Excel JS宏的语法,包括: Selection.Copy(undefined); ActiveCell.Offset(5, 0).Range("A1:M4").Insert(xlShiftDown, undefined); 这里Insert是Excel JS宏中Range对象的一个方法,用于插入单元格或区域。 因此,我们需要区分两种不同的上下文: 1. 纯JavaScript中的自定义插入方法(如引用[1]) 2. 在特定环境(如Excel)中使用JavaScript宏(录制宏)的Insert方法(如引用[2]) 用户询问的是“JS宏insert语法”,根据引用[2]的上下文,很可能是指Excel中的JS宏操作。 所以,我们可以从两个方面回答: (1)纯JavaScript中如何实现插入操作(自定义函数或数组方法) (2)Excel JS宏中Insert方法的使用 同时,引用[3]提到了Python和JavaScript的语法差异,引用[4]提到了树结构的插入操作(数据结构),引用[5]提到PHP的insert,这些与当前问题关系不大。 因此,我们将重点放在引用[1]和引用[2]上。 回答结构: 1. 纯JavaScript中的数组插入(自定义链式插入函数,以及数组的splice方法) 2. Excel JS宏中Insert方法的使用(录制宏生成的代码示例) 注意:用户特别提到“JS宏”,所以可能更关注Excel环境中的宏操作。但为了全面性,我们两者都介绍。 生成相关问题: 1. 如何在纯JavaScript中向数组插入元素? 2. Excel JS宏中Insert方法的具体参数有哪些? 3. 如何录制Excel JS宏来实现插入操作? 由于引用内容有限,我们尽可能基于已有引用内容进行说明。 </think>### JavaScript宏insert语法介绍 JavaScript宏中的"insert"操作通常指在数据结构中插入元素,主要有两类语法: #### 1. 数组插入操作(纯JavaScript) ```javascript // ES6链式插入示例 (引用[1]) let insert = (value) => ({ into: (array) => ({ after: (afterValue) => { const index = array.indexOf(afterValue); array.splice(index + 1, 0, value); // 核心插入语法 return array; } }) }); // 使用示例 insert(2).into([1, 3]).after(1); // 返回 [1, 2, 3] ``` - **核心语法**:`array.splice(startIndex, 0, item)` - `startIndex`:插入位置的索引 - `0`:表示不删除元素 - `item`:要插入的值 - **特点**:原地修改数组,支持链式调用 #### 2. Excel JS宏插入语法(Office脚本) ```javascript // Excel单元格插入示例 (引用[2]) ActiveCell.Offset(5, 0).Range("A1:M4").Insert( Excel.InsertShiftDirection.down, // 插入方向 false // 是否保留格式 ); ``` - **核心方法**:`Range.Insert(shiftDirection, formatOrigin)` - **参数说明**: - `shiftDirection`:指定单元格移动方向(`xlShiftDown`或`xlShiftToRight`) - `formatOrigin`:是否继承相邻格式(`true`/`false`) #### 3. 树结构插入(数据结构应用) ```javascript // 二叉树节点插入伪代码 (引用[4]) class Node { constructor(value) { this.value = value; this.left = null; this.right = null; } } insert(value) { // 递归实现节点插入 if (value < this.value) { if (this.left === null) this.left = new Node(value); else this.left.insert(value); } else { if (this.right === null) this.right = new Node(value); else this.right.insert(value); } } ``` ### 关键差异点 | 场景 | 语法特征 | 返回值 | |-------------|-----------------------------|-------------| | 普通数组 | `array.splice()` | 修改原数组 | | Excel宏 | `Range.Insert()` | 操作工作表 | | 树结构 | 递归插入方法 | 更新树结构 |
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值