一起学习网 一起学习网


快速高效!ADO.NET批量更新数据库的技巧 (ado.net 批量更新数据库)

网络编程 快速高效!ADO.NET批量更新数据库的技巧 (ado.net 批量更新数据库) 09-24

数据库是现代应用程序的核心组成部分,而数据库的性能往往直接影响到应用程序的性能。 在应用程序中频繁读取和写入数据库时,单个操作可能不会影响太大性能,但在大量数据时,这就会变得异常耗时。为了优化性能问题,我们可以使用批量操作,尤其是批量更新,这时ADO.NET是非常出色的选择。本文将详细介绍ADO.NET的批量更新技术,以及如何使用这些技术来提高应用程序的性能。

什么是ADO.NET批量更新?

在使用数据库时,我们通常需要一次处理多行数据,传统的做法是在foreach循环中插入或更新多次数据库。这种方式虽然能够实现我们的目标,但是这种操作方式不可避免地增加了额外的开销。批量操作,尤其是批量更新,显著地提高了性能,使得我们可以在一次操作中更新或插入多行数据。ADO.NET允许我们使用SqlBulkCopy、SqlDataAdapter、SqlCommand等批量更新功能来优化性能。

如何使用ADO.NET批量更新?

1.使用SqlBulkCopy

SqlBulkCopy是一种快速高效地将大量数据复制到SQL Server数据库中的批量复制工具,它适合于将数据从一张表复制到另一张表。 SqlBulkCopy可以在同一个数据库之间,不同的数据库之间移动数据,也可以在SQL Serve实例之间共享数据。

以下是一个使用SqlBulkCopy复制数据的示例:

“`c#

using System.Data.SqlClient;

using System.Data;

//创建连接到数据库

using (SqlConnection conn = new SqlConnection(connectionString))

{

conn.Open();

//创建要复制的数据表

DataTable dataTable = new DataTable();

dataTable.Columns.Add(“Name”, typeof(string));

dataTable.Columns.Add(“Age”, typeof(int));

//使用SqlBulkCopy复制数据到指定的表中

using (SqlBulkCopy bulkCopy = new SqlBulkCopy(conn))

{

bulkCopy.DestinationTableName = “Student”; //指定目标表名

bulkCopy.WriteToServer(dataTable); //复制数据

}

}

“`

可以看到,使用SqlBulkCopy非常简单。我们需要将要复制的数据放入DataTable中,然后指定目标表名并执行WriteToServer方法。

2.使用SqlDataAdapter

SqlDataAdapter是另一种用于批量更新数据的ADO.NET工具。与SqlBulkCopy相比,它更加灵活,可以处理各种修改类型(如插入、更新和删除)。SqlDataAdapter提供了一个Update方法,能够高效地批量更新数据库中的多行数据。

以下是一个使用SqlDataAdapter批量更新数据的示例:

“`c#

using System.Data.SqlClient;

using System.Data;

string connectionString = “Data Source=.;Integrated Security=True;Initial Catalog=myDB;”;

using (SqlConnection sqlConnection = new SqlConnection(connectionString))

{

//创建需要更新的数据集

DataSet dataSet = new DataSet();

SqlDataAdapter dataAdapter = new SqlDataAdapter(“SELECT * FROM Student”, sqlConnection);

dataAdapter.Fill(dataSet, “Student”);

//修改数据集中的数据

foreach(DataRow row in dataSet.Tables[0].Rows)

{

row[“Name”] = “newName”;

}

SqlCommandBuilder builder = new SqlCommandBuilder(dataAdapter);

//使用SqlDataAdapter批量更新数据

dataAdapter.Update(dataSet, “Student”);

}

“`

在这个示例中,我们使用SqlDataAdapter读取数据,将数据保存到本地数据集中,然后通过修改数据集中的数据来更新数据库中的行。使用SqlCommandBuild可以构建Update语句,这样我们就可以使用DataAdapter的Update方法来批量更新数据库中的数据。

3.使用SqlCommand

除了SqlBulkCopy和SqlDataAdapter之外,我们还可以使用SqlCommand类来批量更新数据库。

以下是一个使用SqlCommand批量更新数据库数据的示例:

“`c#

using System.Data.SqlClient;

string connectionString = “Data Source=.;Integrated Security=True;Initial Catalog=myDB;”;

using (SqlConnection sqlConnection = new SqlConnection(connectionString))

{

sqlConnection.Open();

using (SqlCommand sqlCommand = new SqlCommand())

{

sqlCommand.Connection = sqlConnection;

sqlCommand.CommandText = @”UPDATE Student SET age = 25 WHERE Name IN (‘Tom’, ‘Jerry’, ‘Marry’)”;

sqlCommand.ExecuteNonQuery();

}

}

“`

在这个示例中,我们使用SqlCommand将指定的数据更新到数据库中。通过使用WHERE子句限制仅更新指定的行。使用SqlCommand可以轻松地批量更新符合指定条件的数据行。

批量更新是一项重要的性能优化技术。它可以大大提高数据库操作的效率,减少数据库访问时间和数据验证所需的时间。本文主要介绍了ADO.NET使用批量操作技术的方式以及优缺点,让我们更好地利用ADO.NET提供的API来优化我们的应用程序。同时,我们需要注意批量更新所带来的风险,如数据量太大可能会导致应用程序挂起,因此需要根据实际应用场景来选择合适的批量更新方式。

相关问题拓展阅读:

  • ado.net的技术路线
  • 请简描述ADO.NET访问数据库的步骤?

ado.net的技术路线

以往我们对数据库进行操作的方法是先连接上一个数据库,在保持连接的状态下进行数据的各种操作,如增删改查。这样的状况会有两个弊病,一是始终保持连接会造成资源的浪费,二是网络的各种不稳定因素会是这种连接发生丢失,从而对数据的操作也将丢失。

鉴于以上所说道的两个或更多的其他原因,微软提出了另一种操作模式,就是非连接模式的数据操作,当然也没有丢弃以前ado中那种典型的连接模式的数据操作,故而诞生了ado.net及其两种典型的数据操作模式,即连接模式和非连接模式。

当然,无论是采用那种模式来操作数据,首先是要取得数据连接然后对数据源进行操作或对数据源的副本进行操作。则连接为之一步必须完蠢吵成的工作。连接的方法和ado时代没有多大的差别,不外乎与首先建立一个连接对象(或叫做实例化一个连接对象),要完成连接必须知道连接的数据源地址,有的还要知道数据源提供者。下面是典型的列子:

string connString = “Data Source=localhost;Integrated Security=SSPI;Initial Catalog=Northwind;”;

string connstring=”Provider=SQLOLEDB;Data Source=localhost;Initial Catalog=Northwind;”;

//一般来说OLEDB数据源需要设定provider

一次到位的实例化连接对象

OleDbConnection myconn=new OleDbConnection(connstring);

或用Connection的属性设置连接对象的数据源

OleDbConnection myconn=new OleDbConnection();

myconn.ConnectionString=connstring;

接下来就可用connection的open()方法打开连接了

myconn.open()

连接已经完成,接下来进入最重要的数据操作阶段(需要详细了解连接对象建立的同学可以自己去多查查资料哦)

一、连接模式

连接模式下 担负主要责任的对象是DataReader(然而说到DataReader那又不得不提到ExcuteReader()这个方法,因为DataReader是没有构造函数的一个类,DataReader只能通过command类的excutereader()方法来实例化),所以Datareader有以下几个特点:

1.它无构造函数只能通过command的excutereader()方法来实例化,

如:sqlcommand sqlcm=new sqlcommand(); sqldatarader dr =sqlcm.excutereader();

2.它使用数据库时数据库连接必须保持打开状态(在这种状态下无法进行与connection相关的操作)

3.它只能从前往后遍历信息,不能中途停下修改数据

4.基于我前面说过的始终保持连接浪费资源,加上上面的第二条,那指逗么我们必须用完就关闭,如:

dr.close()或者如果我们怕忘记关闭,在实例化时给个参数commandbehavior.closeconnection

sqldatarader dr = cmd.executereader(commandbehavior.closeconnection);

DataReader的用法比较灵活,一般都是通过条件判断来实现,如:

while(dr.reader())

{

…………….

}

也有人为了操作的某种目的,通过DataReader数据读出来,然后存在一个新建的空DataTable中从而将DataReader转唯档卖化成了DataTable,这种做法究竟是否可取,还真是仁者见仁智者见智。如果您实在是想在DataTable和DataReader之间进行转化,可以用下面的方法:

DataReader转DataTable:

DataTable.Load(DataReader对象,LoadOption.OverwriteChanges);

DataTable转DataReader:

DataReader Reader=DataTable.CreateDataReader()

二、非连接模式

非连接模式下担负主要责任的两个对象是DataAdapter和DataSet

非连接模式下DataAdapter起到了一个桥梁的作用,看到这个有的人可能会联想到网络适配器或电源适配器,没错,他们的功能都是一样的,将各种不同的网络类型电源类型转化成统一能够满足要求的类型,这里的DataAdapter就是数据适配器,将各种不同类型的数据源经过适配转化成可以填入Dataset的数据。

DataAdatper对象的使用一般有两种作用,一种是通过command对象如sqlcommand来执行sql语句,从数据源中检测数据,并将检索到的结果填充到DataSet中;还有一种就是把用户对DataSet对象对数据的改变更新到数据源中去。

有人要忍不住问了,为什么非连接模式不需要做这一步呢???

其实连接模式下通过command对象将所有对数据对象的单步操作都直接更新到数据库里去了,这叫单体操作。

而连接模式下Dataset因为和数据服务器断开的,对单体的操作没有机会随时更新到数据库里去,这也就要求有这么一个对象在所有的数据操作完成后对各种数据操作(如增删改等操作)用各种对应的SQL命令统一更新到数据库里去,而这个对象就是DataAdapterle ,所以可以这么说,DataAdapterle 采用的它内嵌的SQL命令集进行的批量SQL操作。

我们首先来看看command和dataadapter的实例化,一般我们可以这样来实例化他们:

OleDbcommand olecmd=new OleDbcommand(sqlString,connObj);

OleDataAdapter oledpt=new OleDataAdapter(sqlString,connObj);

他们都都接收了一个SQL字符串和一个连接对象Connection,那么Command和DataAdapter有什么区别呢?

在面对sql语句时他们的区别是:

Command主要是运行纯粹的SQL命令,直接使SQL语句的操作得以实施。

DataAdapter则内嵌着一套SQL的命令(也就是它的四个属性),如select,delete,insert,update,等到需要执行其中之一的时候还是要Command对象来出面,即对内嵌的命令对象进行实例化,如果没有实例化就调用,常常就会报错,不能通过编译(很多人在用dataadpter的update方法时就出错),所以我们常常会这样的用:

oledpt.selectcomand=new olecommand();

对于取数据

command结合excutereader()利用Datareader来实现

DataAdapter利用Fill()可以实现,但不应非要你用fill来实现。

这里说说Fill()这个方法,打开DataAdapter可以发现,fill()方法来自他的父类的实现,其中Fill方法调用了FillFromCommand或FillFromReader方法。这两个方法中也分别调用了command对象excutereader。所以接下来的事情就不难理解了,感兴趣的朋友可以自己去看看fill的实现方法。

DataAdapter对象可以隐藏和Connection、Command对象沟通的细节,通过DataAdapter对象建立、初始化 DataTable,从而和DataSet对象结合起来在内存存放数据表副本,实现离线式数据库操作。DataAdapter对象允许将DataSet对象中的数据保存到数据源中,也可以从数据源中读取数据,并且也可以底层数据保存体进行数据的添加、删除、更新等操作。

DataAdapter对象含有四个不同的操作命令,分别如下:

(1)、SelectCommand:用来或去数据源中的记录;

(2)、InsertCommand:用来向数据源中新插入一条记录;

(3)、UpdateCommand:用来更新数据源中的数据;

(4)、DeleteCommand:用来删除数剧源中的记录。

值得提出来特别说明的是,在实例化了DataAdapter对象后,此DataAdapter仍然是一个没有实际作用的数据适配器,因为它对数据库和数据集的操作实际上是通过它的四个Command对象(SelectCommand,InsertCommand,UpdateCommand,DeleteCommand)来实现的。所以我们实例化了SqlDataAdapter对象后需要再实例化它相关的SqlCommand对象

SqlAdapter.SelectCommand = new SqlCommand();

SqlAdapter.InsertCommand = new SqlCommand();

SqlAdapter.UpdateCommand = new SqlCommand();

SqlAdapter.DeleteCommand = new SqlCommand();

这四个SqlCommand的引用实际都指向一个SqlCommand对象的实例,另外,利用commandbuilder对象可以自动实例化三个命令(Insertcommand,DeleteCommand,Updatecommand)但注意,要自动生成三个命令须使用实例化好了的SelectCommand来检索所需要的元素,那么就需要注意DataAdapter的实例化方式了,如果采用空参数方法实例化则须单独设置SelectCommand属性,才可以使用commandbuilder,如:

SqlDataAdapter adapter = new SqlDataAdapter();

adapter.SelectCommand = new SqlCommand(queryString, connection);

SqlCommandBuilder builder = new SqlCommandBuilder(adapter);

当如,如果是采用有参数实例化,则无须特别声明selectCommand的属性,因为这种有参数实例化的DataAdapter已经在实例化时自动完成了selectcommand属性,如

SqlDataAdapter adapter = new SqlDataAdapter(“Select * from table”,sqlconn);

SqlCommandBuilder builder = new SqlCommandBuilder(adapter);

所以,一般空参数实例化的dataadapter与selectcommand属性设置时同时出现的。有参数的dataadapter实例化是可以直接使用commandbuilder的。

DataSet的断开模式是相对于数据服务器的断开,不至于每次都要和数据服务器发生连接,而DataSet的数据实际是存在服务的高速缓存中(有的人误以为是存在客户端的,那就大错特错了,想一下便知道,那样数据肯定是不安全的),这也就是说如果数据量大服务器的内存就浪费严重,这也是非连接模式的一个缺点,相比之下DataReader那种读一行存一行的做法就节约内存多了。

三、回顾两种模式的关系

两种模式表面看起来走了两条路线,但有很多共同点,最突出的要数以下两个方面:

1、【开始相同】它们所需的数据连接的形式一样,开始都要通过建立connection对象来完成连接

2、【最终相同】它们都需要在sqlcommand对象的配合下执行sql语句的操作,最终在sqlcommand对象的配合下实现对数据的增删改查操作。

如连接模式的sql操作:

sqlcommand sqlcm=new sqlcommand();//很显然是用了sqlcommand的实例对象

sqldatarader dr =sqlcm.excutereader();

? if(dr.HasRow)

? {

while(dr.read())

{

dr……….//获取字段的值

}

}

非连接模式的sql操作:

sqlDataAdapter slqad=new sqlDataAdapter();

请简描述ADO.NET访问数据库的步骤?

1.创建数据库连接字符创

2.导入命名空间System.data.sqlcen…

3.jia创建SQLCONNECTION 对象 把链接字符创粗前携 放进去

4. 打开岩伏数据库

5.声明SQLcommand对象 括号内放 执行命令的SQL语句 和悔扰connection对象

6command对象。方法执行相关命令

1、Connection,连接。打开数据通道。

2、Command,命令。通过连接传给数据库执行。

3、DataReader,仅向前读取器。通过连接,读取查询结果。

4、Parameter,参数。有输入也有输出,输入参数和Command结合通过连接传橡游给数据库,输出参数在执行后由数据库返回给参数。

5、DataAdapter,

适配器

。将数据库映射到程序磨灶,同步更新、删除、查询、添加。结合DataSet、DataTable、DataRow、DataColumn等对象使用。梁游销

6、Transaction,事物。多个命令组合执行,一条儿失败全部回滚,也可以自己设置还原点,手动控制回滚。

1创建一个数据库链路;

  2请求一个记录;

  3把记则野录信磨暂存到DataSet;

  4如果需要,返回第滑盯斗2步;(DataSet可以容纳多个数据)

  5关闭数据库链路;

  6在DataSet上作所需要的操作。

1.添加一个连接数据库的类DBHelper(主要添加连接语句string s = “连接语行升侍句”,及创建SqlConection con = new SqlConnection(s))

2.在笑察操作的窗体事件中引用using system.Data.SqlClient;

创建sqlconnection 对象sql ;sql.open();打开数据库连接;创建sqlcommand对象 (sqlcommand cmd = new sqlcommand(sql操作语句,sql))档吵

3.关闭数据库连接(sql.close();

1.创建连接sqlconntion con = new sqlconntion ();

2.打开连接锋裂con.open();

3.指定命令:sqlcommand cmd = new SqlCommand(sql语芦悄句, con)

4.关闭连接银哗闭

con.close();

关于ado.net 批量更新数据库的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。


编辑:一起学习网

标签:数据,对象,操作,批量,数据库