在ASP.NET中向數(shù)據(jù)庫批量插入數(shù)據(jù)
作者:佚名
向數(shù)據(jù)庫中批量插入數(shù)據(jù),可以將若干條數(shù)據(jù)一次插入道數(shù)據(jù)庫,提高程序的執(zhí)行效率.在ASP.NET中向數(shù)據(jù)庫批量插入數(shù)據(jù)中介紹兩種方法:利用事務和利用Dataset?!?/div>
在我們平時的ASP.NET開發(fā)過程中,經(jīng)常要向數(shù)據(jù)庫插入數(shù)據(jù),有時可能要進行很多次類似的操作,比如向數(shù)據(jù)庫中的同一個表同時插入若干數(shù)據(jù),即批量插入數(shù)據(jù)。
向數(shù)據(jù)庫中批量插入數(shù)據(jù),可以將若干條數(shù)據(jù)一次插入到數(shù)據(jù)庫,提高程序的執(zhí)行效率,也可以減少我們的工作量。
ASP.NET批量插入數(shù)據(jù),可以采用一下兩種方法。
一、利用事務(Transaction)
‘定義執(zhí)行批量插入數(shù)據(jù)的函數(shù),參數(shù)為Insert SQL語句的數(shù)組
- 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) ‘取得參數(shù)(數(shù)組)中的值
- cmd.ExecuteNonQuery()
- Next
- Trans.commit()
- Catch ex as oledbexception
- Trans.Rollback()
- Fanlly
- Conn.close()
- End try
- End sub
二、利用Dataset
- public sub Insert()
- ‘建立datatable數(shù)據(jù)源
- 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
利用以上ASP.NET的兩種方法,都可以完成向數(shù)據(jù)庫批量插入數(shù)據(jù)。
【編輯推薦】
責任編輯:冰荷
來源:
ctocio


相關推薦
2009-07-28 12:48:50




