① 求sql怎么一次用insert 添加多条数据
数据库没有真正意义的多条数据同时添加。
只是把多条insert语句连续书写,实际还是一条一条添加。
数据库每一条记录添加会有相关触发操作,比如主键判断、触发器,所以不可能同时添加多条记录。
② 用sql语句批量增加数据
批量增加数据,能再具体点吗,具体问题的处理方式不同,如果要从一张表中取数据,增加到另一张表中,那直接
insert
tableA
select
column1,column2....from
tableB
where
......(where条件根据实际需要)
这样就可以实现批量插数据
insert
tableA(column1,column2....)
values(a,b,c,...)这种只能一次插一条
如果还复杂点的话,也可以用循环来做。
③ 向sql 数据库中增加多条数据,用sql命令怎么写急!急!急!
如果没有规律就不好办,你可以先插入多条一样的数据,然后到管理器去修改name 和times_money 的值,能快点。要不就写个存储过程,不过时间长,看你数据多少了,一般大数据量可以通过导入的方式录入。
④ 求sql怎么一次用insert 添加多条数据
用insert 添加多条数据:
insert into 表1(列名) select 列名 from 表2 --主键要自增
对于主键不自增的也可以处理,如:建一张临时表,主键ID自增,然后取出要插入有的最大值,把最大值加到临时表ID上再用:insert into 表1(ID,列名) select ID,列名 from 表2
insert into persons
(id_p, lastname , firstName, city )
values
(200,'haha' , 'deng' , 'shenzhen'),
(201,'haha2' , 'deng' , 'GD'),
(202,'haha3' , 'deng' , 'Beijing');
⑤ 求sql怎么一次用insert 添加多条数据
可以一次加入多条记录。
在SQL
SERVER里边,多个INSERT
语句之间,用分号(;)或者空格,隔开,这样数据库就认为你是在进行多条SQL语句的插入操作。就可以插入多条了。
⑥ 求sql怎么一次用insert 添加多条数据
用insert 添加多条数据:
insert into 表1(列名) select 列名 from 表2 --主键要自增
对于主键不自增的也可以处理,如:建一张临时表,主键ID自增,然后取出要插入有的最大值,把最大值加到临时表ID上再用:insert into 表1(ID,列名) select ID,列名 from 表2
⑦ 求sql怎么一次用insert 添加多条数据
如果是sqlserver支持多sql语句,你可以将所有的insert拼接成字符串,一起发送到服务器
或者你可以批量插入另一个数据集的数据
insert xxx(id,name) select id,name from xxx
⑧ 求sql怎么一次用insert 添加多条数据
--一条insert只能插入一行数据,除非你有一个相同数据类型的表需要复制表数据批量插入可以使用
InsertintoTable2(field1,field2,...)selectvalue1,value2,...fromTable1
--要求目标表Table2必须存在,由于目标表Table2已经存在,所以我们除了插入源表Table1的字段外,还可以插入常量。
⑨ 求sql怎么一次用insert 添加多条数据
数据库是没有真正的批量新增记录。因为每新增一个条记录数据库系统要进行校验,比如触发器。
可以用多条insert语句,类似批量添加多条记录。
比如 :
insert into table values(var1...);
insert into table values(var2...);
...
insert into table values(varN...);
不过,实质上数据库还是逐条添加的,并不是同时添加所以尽量。
⑩ sql 一次插入多条记录
在使用sql数据库的时候,我们也许会需要一次像数据库中添加多条记录,那么我们可以使用sql语句来实现,该语句具体如下:
--添加一条记录
insert
into
tablename(col1,col2,col3)
values
(1,2,3)
--添加多条记录
insert
into
tablename(col1,col2,col3)
select
3,4,5
union
all
select
6,7,8
--从另外的一张表中读取多条数据添加到新表中
insert
into
tablename(col1,col2,col3)
select
a,b,c
from
tablea
--从其他的多张表中读取数据添加到新表中
insert
into
tablename(col1,col2,col3)
select
a,b,c
from
tablea
where
a=1
union
all
select
a,b,c
from
tableb
where
a=2
上边代码中的into都可以省略!
上边代码中的union
all如果换成union,则相同记录只插入一次,不会重复插入。
另外一种方法是sql
server2008特有的,所以,如果你不是sql
server2008,就不能使用这种方法了。
insert
into
mytable(id,name)values(7,'003'),(8,'004'),(9,'005')
create
table
[test]
(
[num_id]
int
primary
key
)
go
declare
@temp
int
set
@temp=1;
while
@temp<=1000000
begin
insert
into
[test]([num_id])
values(@temp)
set
@temp=@temp+1;
end
go
----------------------------------------------------------
--试试下面的方法
--2005
declare
@n
as
bigint;
set
@n
=
1000000;
with
base
as
(
select
1
as
n
union
all
select
n
+
1
from
base
where
n
<
ceiling(sqrt(@n))
),
expand
as
(
select
1
as
c
from
base
as
b1,
base
as
b2
),
nums
as
(
select
row_number()
over(order
by
c)
as
n
from
expand
)
select
n
from
nums
where
n
<=
@n
option(maxrecursion
0);
--2
create
function
dbo.fn_nums(@n
as
bigint)
returns
table
as
return
with
l0
as(select
1
as
c
union
all
select
1),
l1
as(select
1
as
c
from
l0
as
a,
l0
as
b),
l2
as(select
1
as
c
from
l1
as
a,
l1
as
b),
l3
as(select
1
as
c
from
l2
as
a,
l2
as
b),
l4
as(select
1
as
c
from
l3
as
a,
l3
as
b),
l5
as(select
1
as
c
from
l4
as
a,
l4
as
b),
nums
as(select
row_number()
over(order
by
c)
as
n
from
l5)
select
n
from
nums
where
n
<=
@n;
go
--2000
这个会比前两个慢,但是前两个2000不能用
create
table
dbo.nums(n
int
not
null
primary
key);
declare
@max
as
int,
@rc
as
int;
set
@max
=
1000000;
set
@rc
=
1;
insert
into
nums
values(1);
while
@rc
*
2
<=
@max
begin
insert
into
dbo.nums
select
n
+
@rc
from
dbo.nums;
set
@rc
=
@rc
*
2;
end
insert
into
dbo.nums
select
n
+
@rc
from
dbo.nums
where
n
+
@rc
<=
@max;
--------------------------------------------------------------------------------------------------------