当前位置:首页 » 编程语言 » sql插入多条列数据
扩展阅读
webinf下怎么引入js 2023-08-31 21:54:13
堡垒机怎么打开web 2023-08-31 21:54:11

sql插入多条列数据

发布时间: 2023-01-05 16:37:26

Ⅰ 求sql怎么一次用insert 添加多条数据

用insert 添加多条数据:
insert into 表1(列名) select 列名 from 表2 --主键要自增
对于主键不自增的也可以处理,如:建一张临时表,主键ID自增,然后取出要插入有的最大值,把最大值加到临时表ID上再用:insert into 表1(ID,列名) select ID,列名 from 表2

insertintopersons
(id_p,lastname,firstName,city)
values
(200,'haha','deng','shenzhen'),
(201,'haha2','deng','GD'),
(202,'haha3','deng','Beijing');

Ⅱ 如何使用一条SQL语句,插入多条记录

有三种方法:
1.InSert Into <表名>(列名)
Select <列名>
From <源表名>
如:INSERT INTO TongXunLu (姓名,地址,电子邮件)
SELECT SName,SAddress,SEmail
FROM Students 这种方法需要先建好新表.

2.Select (列名)
Into <表名>
From <源表名>
如:SELECT Students.SName,Students.SAddress,Students.SEmail
INTO TongXunLu
FROM Students 这种方法SQL自动建表

3.InSert Into <表名>(列名)
Select <列名> Union
Select <列名> Union
……
如:INSERT STUDENTS (SName,SGrade,SSex)
SELECT '张可',7,1 UNION
SELECT '李扬',4,0 UNION
SELECT '杨晓',2,0 UNION
SELECT '汤美',3,0 UNION
SELECT '苏三东',7,1 UNION
SELECT '王立岩',3,1 UNION
SELECT '张伟',7,1 UNION
SELECT '陈刚',4,1 UNION
SELECT '王娟娟',7,0

Ⅲ sql 多列插入数据

类似这样做吧.

create table #1 (Time datetime)--select * from #1
declare @i int,@StartTime datetime
select @i = 0,
@StartTime = '2010-3-17 8:30:00'
while @i < 5
begin insert into #1 values(dateadd(dd,@i,@StartTime))
set @i=@i+1
end
select * from #1
drop table #1

Ⅳ 求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一般是用来给表插入一条指定的列值的,但是,insert还存在另一种形式,可以利用它将一条select语句的结果插入表中。

这就是所谓的insert select,顾名思义,它是由一条insert语句和一条select语句组成的。假如你从另一张表中合并客户列表到你的Custumers表,不需要每次读取一行,然后再将它用insert插入,可以如下进行:

insert into Custumer(cust_id,

cust_cintact,

cust_name,

cust_email,

cust_address,

cust_country)

select cust_id,

cust_cintact,

cust_name,

cust_email,

cust_address,

cust_country

from CustNew;

(5)sql插入多条列数据扩展阅读

insert select中的列名为简单起见,这个例子在insert和select语句中使用了相同的列名,但是,不一定要求列名匹配。事实上,DBMS甚至不关心select返回的列名,它使用的是列的位置。

因此,select中的第一列(不管其列名)将用来填充表列中的指定的第一个列,第二列将用来填充表列中指定的第二个列,如此等等。

Ⅵ 如何一次向SQL Server Insert多条记录

楼主好,首先要看你插入的是什么数据,是枚举型的还是结果集。枚举类型插入多条的语法如下:

insertinto目标表
(列名1,列名2,···,列名n)
values
(A内容1,A内容2,···,A内容n),
(B内容1,B内容2,···,B内容n),
····,
(N内容1,N内容2,···,N内容n)

如果你插入的是查询的结果集

insertinto目标表
(列名1,列名2,···,列名n)
select列1,列2,···,列nfrom表

当然,插入的结果集可以是各种查询,比如关联查询,复杂查询等等,也可以是派生列。

Ⅶ 如何一次插入多条记录的SQL语句

在使用SQL数据库的时候,我们也许会需要一次像数据库中添加多条记录,那么我们可以使用SQL语句来实现,该语句具体如下:x0dx0a--添加一条记录 x0dx0aINSERT INTO tableName(col1,col2,col3) VALUES (1,2,3) x0dx0a x0dx0a--添加多条记录 x0dx0aINSERT INTO tableName(col1,col2,col3) x0dx0aSELECT 3,4,5 x0dx0aUNION ALL x0dx0aSELECT 6,7,8 x0dx0a x0dx0a--从另外的一张表中读取多条数据添加到新表中 x0dx0aINSERT INTO tableName(col1,col2,col3) x0dx0aSELECT a,b,c FROM tableA x0dx0a x0dx0a--从其他的多张表中读取数据添加到新表中 x0dx0aINSERT INTO tableName(col1,col2,col3) x0dx0aSELECT a,b,c FROM tableA WHERE a=1 x0dx0aUNION ALL x0dx0aSELECT a,b,c FROM tableB WHERE a=2 x0dx0a上边代码中的into都可以省略!x0dx0a上边代码中的union all如果换成union,则相同记录只插入一次,不会重复插入。x0dx0a另外一种方法是SQL Server2008特有的,所以,如果你不是SQL Server2008,就不能使用这种方法了。 x0dx0aINSERT INTO MyTable(ID,NAME)VALUES(7,顛'),(8,顜'),(9,顝')x0dx0acreate table [TEST]x0dx0a(x0dx0a [NUM_ID] int primary keyx0dx0a)x0dx0agox0dx0adeclare @temp intx0dx0aset @temp=1;x0dx0awhile @temp<=1000000 x0dx0abeginx0dx0ainsert into [TEST]([NUM_ID]) values(@temp)x0dx0aset @temp=@temp+1;x0dx0aendx0dx0agox0dx0a----------------------------------------------------------x0dx0a--试试下面的方法x0dx0a--2005x0dx0aDECLARE @n AS BIGINT;x0dx0aSET @n = 1000000;x0dx0aWITH Base ASx0dx0a(x0dx0a SELECT 1 AS nx0dx0a UNION ALLx0dx0a SELECT n + 1 FROM Base WHERE n < CEILING(SQRT(@n))x0dx0a),x0dx0aExpand ASx0dx0a(x0dx0a SELECT 1 AS cx0dx0a FROM Base AS B1, Base AS B2x0dx0a),x0dx0aNums ASx0dx0a(x0dx0a SELECT ROW_NUMBER() OVER(ORDER BY c) AS nx0dx0a FROM Expandx0dx0a)x0dx0aSELECT n FROM Nums WHERE n <= @nx0dx0aOPTION(MAXRECURSION 0);x0dx0a--2x0dx0aCREATE FUNCTION dbo.fn_nums(@n AS BIGINT) RETURNS WITHx0dx0a L0 AS(SELECT 1 AS c UNION ALL SELECT 1),x0dx0a L1 AS(SELECT 1 AS c FROM L0 AS A, L0 AS B),x0dx0a L2 AS(SELECT 1 AS c FROM L1 AS A, L1 AS B),x0dx0a L3 AS(SELECT 1 AS c FROM L2 AS A, L2 AS B),x0dx0a L4 AS(SELECT 1 AS c FROM L3 AS A, L3 AS B),x0dx0a L5 AS(SELECT 1 AS c FROM L4 AS A, L4 AS B),x0dx0a Nums AS(SELECT ROW_NUMBER() OVER(ORDER BY c) AS n FROM L5)x0dx0a SELECT n FROM Nums WHERE n <= @n;x0dx0aGOx0dx0a--2000 这个会比前两个慢,但是前两个2000不能用x0dx0aCREATE TABLE dbo.Nums(n INT NOT NULL PRIMARY KEY);x0dx0aDECLARE @max AS INT, @rc AS INT;x0dx0aSET @max = 1000000;x0dx0aSET @rc = 1;x0dx0aINSERT INTO Nums VALUES(1);x0dx0aWHILE @rc * 2 <= @maxx0dx0aBEGINx0dx0a INSERT INTO dbo.Nums SELECT n + @rc FROM dbo.Nums;x0dx0a SET @rc = @rc * 2;x0dx0aENDx0dx0aINSERT INTO dbo.Numsx0dx0a SELECT n + @rc FROM dbo.Nums WHERE n + @rc <= @max; x0dx0a--------------------------------------------------------------------------------------------------------

Ⅷ plsql怎么往表里插入多条数据

1、采用insert into values 语句插入一条,写很多条语句即可多条数据,这种主要针对于离散值以及一些基础信息的录入,如:insert into test(xh,mc) values('123','测试');
如果插入的数据有规律,可利用for、loop循环插入,主要用于批量生成测试数据
begin
for i in 1 .. 100 loop
insert into test(xh,mc) values(i||'','测试');
end loop;
end ;。
2、采用insert into selct from 语句来一次性插入一个集合,这种主要依据于要插入的数据源已经存储于数据库对象中,或者利用al虚表来构造数据,经过加工后写入一个集合。
insert into test (xh,mx) select '123','测试' from al;
3、采用plsql等工具、或者oracle的imp、impdp命令来导入,这种主要用数据库与数据库之间的大批量数据导入,导入的数据格式为plsql的pde、oracle的dmp等。dmp文件可使用
table_exists_action参数控制导入动作:replace替换原表,truncate清除原表数据再导入,append增量导入数据,当然impdp数据泵的导入要依赖于directory路径。
impdp 用户名/密码 mpfile=123.dmp logfile=123.log directory=imp_dir tables=test table_exists_action=append
4、使用excel文件直接拷贝。这种主要用于要写入的数据已是excel文件或者行列分明的其它格式文件,每一列的值和表结构相对应,可直接打开表的行级锁,把数据拷贝进入。
打开行级锁方法:
select t.*,rowid from 表名 t where 1=2;
select * from 表名 where 1=2 for update;
直接把excel数据拷贝到表里

Ⅸ sql中添加一列中的多条数据

要建2各表。
1.A表ID建(类似于类别)
2.B表NAME建(类似于新闻条数)
添加B表多条信息的时候,可以同时添加A表的ID,B表里就是NAME内容不一样。ID就是相同的。