您的位置:首页 > 博客中心 > 数据库 >

C#与数据库访问技术总结(十八)

时间:2022-03-14 03:14

 

   上述代码演示了从根据连接字符串建立连接对象,到创建DataAdpate对象填充DataSet,再到使用DataSet对象提交数据更新以及与DataGrid绑定的一般过程。

      上述代码也演示了使用Connection、DataAdapter和DataSet访问数据库的一般流程。

  ADO.NET采用离线的方式访问数据库,所以使用DataSet从数据库获得数据后的操作数据的过程中,不必保持与数据库的连接,直到向数据库提交更新数据时,才需连上数据库。这种做法适合于海量数据更新的情况。

     而在上述代码里,因为数据操作过程比较简单,所以直到数据更新提交结束才断开连接,也就是说,并没有采用“离线”的数据库连接访问方式。

  不采用“离线”方式的理由是:在数据库访问操作中,频繁连接和断开数据源也需要耗费一定的系统资源,如果这个代价要比保持短时间的数据连接所需的代价大,那么宁可选择“一直在线”的连接方式。

使用SQL Server .NET  Provider

  

  以下的代码演示了如何使用SQLServer的.NETProvider来连接和访问数据。
//连接字符串
string connectionString="server=local;database=Northwind;user=sa;pwd=;";
//建立连接
Sqlconnection =new SqlConnection(connectionString);
//SQL语句
string strSql= "select UserID, UserName from User";
//根据连接对象和SQL语句创建SqlCommand对象
SqlCommand cmd=new SqlCommand(strSql, conn);
conn.Open();
//使用Command对象创建SqlDataReader对象
SqlDataReader  reader=cmd.ExecuteReader();
//使用DataReader对象填充DataGrid 控件
DataGrid_User.DataSource=reader;
DataGrid_User.DataBind();
//关闭连接
conn.Close();
   上述代码也演示了使用Connection、Command和DataReader对象访问数据库的一般方式。

 

数据库访问综述

    前面讲述了用两种不同的数据提供者(Provider)访问连接数据库的方式,如果数据源是SQL Server,则使用SQL Server的Provider;如果数据源是ODBC或是其他类型的数据库,则可以选用OLE DB的Provider。

    前面还讲述了使用Connection+Command+DataReader对象和使用Connection+ DataAdapter+DataSet对象的数据库访问方式。

    根据DataReader的特性,以Connection+Command+DataReader方式访问数据库的使用场景有:

  • 字    段

    中文描述

    数据类型

    备    注

    SID

    学号

    文本

    主键

    SName

    姓名

    文本

      一 

    Sex

    性别

    文本

      一 

     

     

     

     

     

     

    注意:本书表中“一”表示无须设置相关信息。

        完成后往其中插入一些记录,如(001,Tom,Male)。

        (2)打开Visual Studio环境后,选择“文件”|“新建”|“新建网站”命令,在弹出的新建网站”对话框中选择“ASP.NET项目”,输入网站名testDataGrid和路径CAroot~DataGrid,登录模块所有代码和配置文件均放在此项目下。

        (3)在集成开发环境中的“解决方案资源管理器”里,选中项目,右击,在弹出的快捷菜单中选择“添加新项”命令,新建一个Web配置文件,命名为Web.config。该配置文件主要用来管理登录模块的一些全局性数据。

        其中,在配置文件里设置数据库的连接属性,使用OleDB的Data Provider,连接到Access数据源上,代码如下。

      

    <configuration>
      <appSettings>
    <add key="connStr" value="Porvider=Microsoft.Jet.OleDB.4.0; Data Source=D:\login.mdb "></add>
      </appSettings>
    <connectionStrings />

     

       (4)在集成开发环境中的“解决方案资源管理器”里,选中项目,右击,在弹出的快捷菜单中选择“添加新项”命令,新建一个Web窗体,命名为showDataGrid.aspx。

        (5)打开“工具箱”的“Web窗体”,从中拖曳一个DataGrid控件到页面上,从DataGrid的属性栏中,可以看到该DataGrid对象叫DataGrid1。

        选中DataGridView控件,右击,在弹出的快捷菜单中选择"属性"命令,在属性栏的Columns中单击“…”按钮,在弹出的“编辑列”对话框中,通过“添加”命令,依次向DataGridView控件里添加“学号”、“姓名”和“性别”3列,并把每列的DataPropertyName设置成该列对应的数据库字段,用于数据绑定。具体设置如表所示。

    数据列名

    DataPropertyName

    学号

    SID

    姓名

    SName

    性别

    Sex

     

     

     

     

     

     

    (6)双击窗体的空白处,进入相应的逻辑代码文件showDataGrid.aspx.cs。

      在该文件的顶端,添加数据库访问引用的命名空间语句:    

      using System.Data.SqlClient;

     

      并在class的开头添加连接数据库的字符串定义:     

    Private static string strConnect =System.Configuration.ConfigurationManager.AppSettings["connstr"];

     

      由于使用的是DataProvider,所以ADO.NET组件的对象都以OleDb开头。

        上述代码的主要业务逻辑是:

        (1)根据连接字符串,创建数据库连接对象,并根据连接对象创建OLeDbCommand对象。

        (2)根据SQL语句,查询所有学生的信息,以SID的/顷序排列。

        (3)使用OleDbDataApapter对象,将查询结果填充到DataSet中的。均Dataset数据表里。

        (4)将DataGrid的数据源设置成。均Dataset数据表,实现数据绑定。

        这样,当打开此页面时,DataGrid就能与Access数据库绑定,显示数据库里的学生信息。

热门排行

今日推荐

热门手游