资源描述:
《C#数据库操作(修复的).doc》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、个人收集整理勿做商业用途11.3ADO.NET概念ADO.NET是由很多类组成的类库,这些类提供了许多对象,分别用来实现连接数据库,查询数据,插入数据,更新数据和删除数据等操作。ADO.NET提供了下面两种访问数据库的方法(1)利用Connection,Command和DataReader对象访问数据库。这种方式只能从数据库读取数据,不能添加,修改和删除基类。如果只是进行查询,这种方式效率更高一些(2)利用Connection,Command,DataAdapter和DataSet对象。这种方式比较灵活,不仅可以读取数据库进行查询操作。还可以进行添加,删除和修改等操作。另外,A
2、DO.NET对象模型主要由两个基本组件构成;一个是ADO.NET数据库提供程序,用于连接到数据库,执行命令和检查结果;另一个是数据集(DataSet),DataSet对象是支持ADO.NET的断开式,分布式数据方案的核心对象。1.NETDataProvider.NET 数据提供者是指存取数据源的一组类库,主要是为了统一各类型数据源的存取方式而设计出一套高效类库。在.NETData Provider中包括了下表四个对象对象名称功能说明Connection提供和数据源的连接功能Command提供存取数据库命令,并执行传送数据或修改数据的命令,例如执行SQL命令,预存程序。DataA
3、dapter担任DataSet对象和数据源间的桥梁。DataAdapter使用四个Command对象执行查询,新增,修改,删除的SQL命令,把数据加载DataSet,或者把DataSet内的数据更新返回数据源。DataReader通过Command对象执行SQL查询命令取得数据流,以便进行高速,只读的数据浏览功能DataSet该对象可视为一个虚拟的数据源。在该对象中,存在着许多DataTable对象。DataTable对象可以看作一个内存中的Table,开发人员可以自定义Table中的栏目来在显示数据,也可以通过将不同数据源的数据存在不同DataTable对象的方式将这些数据整
4、合在一起。11.4ADO.NET对象不同的数据提供程序会由于其所用的数据库技术不同而有不同的实现方式。它们提供了对底层数据源的访问,包括四个数据对象,其分别是Connection对象,Command对象,DataReader对象和DataAdapter对象。11.4.1Connection对象 Connection对象用于连接到数据源。ADO.NET中包括OleDbConnection和SqlConnection等对象,前者用来连接基于OLEDB的数据库,后者专门用来连接SQL Server数据库。(1)使用SqlConnection对象连接到SQLServer数据库个人收集整
5、理勿做商业用途连接到数据库是访问数据库的第一步,可以使用下面的语句连接到SQL Server的pubs数据库StringConnectionString=“server=(local);uid=sa;pwd=;database=pubs”;如果是Windows身份验证时;则连接字符串具有如下形式Data Source=(local);Initial Catalog=数据库名;Integrated Security=True;SqlConnectionMyConnection=newSqlConnection(ConnectionString)其中,ConnectionStrin
6、g变量存储了访问数据库的各种信息,server用于指定运行SQL Server的服务器;uid和pwd分别指定登录到SQL Server服务器的用户名和密码;database指定数据库名,MyConnection变量为SqlConnection类型的变量,代表了实际的连接对象(1)使用OleDbConnection对象连接到OLE数据源进行数据库的连接需要使用连接字符串,连接OLE DB数据库(以Access数据库为例)的Connection对象的语句为 String ConnectionString=“Provider=Microsoft.Jet.OLEDB.4.0”;Dat
7、aSource=“文件路径及文件名”; 如果数据库使用Access2007版本编写的时候连接字符串改为StringConnectionString=“Provider=Microsoft.ACE.OLEDB.12.0”;DataSource=“文件路径及文件名”;(1)注意DataSource要分开写即中间要留有空格OleDbConnection MyConnection=newOleDbConnection(ConnectionString)其中Provider提出了OLEDB数据库的驱动