在ASP.NET中,向数据库批量插入数据
来源:互联网 发布:使用pdo连接mysql 编辑:程序博客网 时间:2024/06/02 11:55
在我们平时的开发过程中,经常要向数据库插入数据,有时可能要进行很多次类似的操作,比如向数据库中的同一个表同时插入若干数据,即批量插入数据。
向数据库中批量插入数据,可以将若干条数据一次插入道数据库,提高程序的执行效率,也可以减少我们的工作量。
批量插入数据,可以采用一下两种方法。
一、利用事务(transaction)
‘定义执行批量插入数据的函数,参数为insert SQL语句的数组
sub ExeTransaction (Byval Sqlstrlist as string())
dim Conn As String = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=Tax.mdb"
dim trans as OledbTransaction=Nothing
try
if conn.State=connectionstate.closed then
conn.open()
end if
dim cmd as oledbCommand=new oledbcommand()
cmd.connection=conn
cmd.commandtype=commandtype.text
trans=conn.begintransaction()
cmd.transaction=trans
dim I as integer
for I=0 to Sqlstrlist.GetupperBound(0)
cmd.commandtext= Sqlstrlist(i) ‘取得参数(数组)中的值
cmd.executenonquery()
next
trans.commit()
catch ex as oledbexception
trans.rollback()
fanlly
conn.close()
end try
end sub
二、利用dataset
public sub Insert()
‘建立datatable数据源
dim dt as DataTable=New DataTable()
dim dr as DataRow
dt.columns.add(new DataColumn(“name”))
dim j as Integer
for j =0 to 10
dr=dt.newrow()
dr(0)=”name”+j.tostring
dt.rows.add(dr)
next
dim Conn As String = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=Tax.mdb"
conn.open()
dim MyAdapter as Oledbdataadapter=new OleDataAdapter()
….
dim cmd as Oledbcommand=New Oledbcommand(“Insert Into table(name) values (@name)”,conn)
cmd.parameters.item(“@name”).SourceColumns=dt.columns(“name”).columnsName
myadapter.update(dt)
conn.close()
end sub
利用以上的两种方法,都可以完成向数据库批量插入数据。
--下面是在SQL中,直接用SQL语句读取几种常见的文件格式中的数据--/* 文本文件
select * from
OPENROWSET('MICROSOFT.JET.OLEDB.4.0'
,'Text;HDR=NO;DATABASE=C:/' --c:/是目录
,aa#txt) --aa#txt是文本文件名aa.txt
--*/
--/* Excel文件
select * from
OPENROWSET('MICROSOFT.JET.OLEDB.4.0'
,'Excel 8.0;IMEX=1;HDR=YES;DATABASE=c:/test.xls' --c:/test.xls是excel文件名
,sheet1$)
--/* dBase IV文件
select * from
OPENROWSET('MICROSOFT.JET.OLEDB.4.0'
,'dBase IV;DATABASE=C:/' --c:/是目录
,'select * from [客户资料4.dbf]') --客户资料4.dbf是文件名
--*/
--/* dBase III文件
select * from
OPENROWSET('MICROSOFT.JET.OLEDB.4.0'
,'dBase III;DATABASE=C:/'
,'select * from [客户资料3.dbf]')
--*/
--/* FoxPro 数据库
select * from openrowset('MSDASQL',
'Driver=Microsoft Visual FoxPro Driver;SourceType=DBF;SourceDB=c:/', --c:/是目录
'select * from [aa.DBF]') --aa.dbf是文件名
/*--说明:
SourceDB=c:/ c:/是dbf文件的存放目录
[aa.DBF] 是dbf文件名
--*/
bulk insert
有一文件[D:/msql/bulk.txt]内容如下.以空格分隔.
01 gwf dongguang CSDN.net
02 sxl dongguangeric CSDN.net
--建表:
if object_id('tbulk') is not null drop table tbulk
create table tbulk(id int,name varchar(100),addr varchar(100),tag varchar(10))
Go
--批次处理
bulk insert tbulk from 'D:/msql/bulk.txt'
with (
fieldterminator=' ' --列分隔符
-- rowterminator='/n' --行分隔符
)
--结果
select * from tbulk
- 在ASP.NET中,向数据库批量插入数据
- 在ASP.NET中,向数据库批量插入数据
- 在ASP.NET中,向数据库批量插入数据
- 在ASP.NET中,向数据库批量插入数据
- 在ASP.NET中,向数据库批量插入数据
- 在ASP.NET中,向数据库批量插入数据
- ASP.NET中,向数据库批量插入数据
- ASP.NET 向SQLSERVER中批量插入数据
- .net批量向Oracle数据库中插入数据
- 向数据库中批量插入数据
- ASP.NET中批量插入数据
- asp中向数据库不能插入数据
- 向数据库插入批量数据
- ASP.NET批量插入数据
- 求救:如何在asp页面里向数据库插入数据
- ASP.NET中实现批量插入oracle数据库
- JDBC批量向数据库插入数据(十)
- asp.net 中数据的批量插入和更新
- 如何从硬盘的镜像文件上安装linux/fedora core?
- 假网站骗密码划钱不要点击
- uddi4j类的简单介绍
- 坚守还是追新,开发者如何应对新技术暗潮
- Oracle数据库配置错误信息解决方法
- 在ASP.NET中,向数据库批量插入数据
- 网站维护提示
- 基于Lotus Notes 8 的银行业复合应用举例
- 转 mysql my.cnf的优化
- c/c++经典积累
- [DB2 学习记录]7. 创建DB
- hash加密为什么不能破?
- PHP开发一个完整、安全的用户登录系统
- 如何区别重载、覆盖与隐藏