zoukankan      html  css  js  c++  java
  • 一步步写自己SqlHelper类库(六):DataAdapter对象

    1.DataAdapter 对象来龙去脉

    前面我所介绍的ADO.NET对象中,例如Connection对象,Command对象以及DataReader对象,这些对象均属于Data Provider的一部分,而且都是基于连接的。如果,每次我们检索数据库中的表或者行都需要连接一次数据库,那么性能和效率是十分低下的。实际上,ADO.NET提供了基于非连接的核心组件:DataSet。那么存储的数据集合是从哪里来呢?ADO.NET就为DataSet提供了中介:DataApdater数据适配器。

    定义:DataAdapter 对象提供连接 DataSet 对象和数据源的桥梁,DataAdapter 使用 Command 对象在数据源中执行 SQL 命令以向 DataSet 中加载数据,并将对 DataSet 中数据的更改协调回数据源。

    2.DataAdapter的工作原理

    下面我们以Customer表为例,来理解DataAdapter的工作原理。下图详细描述了一个DataAdapter的工作过程。

    3.DataAdapter的属性和方法

    3.1属性

    尽管DataAdapter类包含很多属性和方法,但很可能每次只使用它们的某个子集。使用DataAdapter可对来自数据源的记录进行操作。通过使用4个DataAdapter属性(指定执行某条SQL语句或调用某个存储过程)中的一个,可以指定所要执行的操作。这些属性实际上是Command类的实例对象:

    SelectCommand:引用从数据源中检索行的Command对象。

    InsertCommand:引用将插入的行从DataSet写入数据源的Command对象。

    UpdateCommand:引用将修改的行从DataSet写入数据源的Command对象。

    DeleteCommand:引用从数据源中删除行的Command对象。

    3.2方法

    使用DataAdapter提供的方法,可以填充DataSet或将DataSet表中的更改传送到相应的数据存储区。这些方法包括:

    Fill:使用DataAdapter的这个方法,从数据源增加或刷新行,并将这些行放到DataSet表中。Fill方法调用SelectCommand属性所指定的SELECT语句。

    Update:使用DataAdapter对象的这个方法,将DataSet表的更改传送到相应的数据源中。该方法为DataSet的DataTable中每一指定的行调用相应的INSERT、UPDATE或DELETE命令。

    4.入门例子

    public void SqlAdapterDemo(string connStr)
    {
      SqlConnection conn = new SqlConnection(connStr);//连接对象
    
      SqlCommand cmd = conn.CreateCommand();//sql命令对象
      cmd.CommandType = CommandType.Text;
      cmd.CommandText = "select * from products = @ID";//sql语句
    
      cmd.Parameters.Add("@ID", SqlDbType.Int);
      cmd.Parameters["@ID"].Value = 1;//给参数sql语句的参数赋值
    
      SqlDataAdapter adapter = new SqlDataAdapter();//构造SqlDataAdapter
      adapter.SelectCommand = cmd;//与sql命令对象绑定,这个必不可少
    
      DataSet ds = new DataSet();
      adapter.Fill(ds);//填充数据。第二个参数是数据集中内存表的名字,可以与数据库中的不同
                                      //Fill方法其实是隐藏的执行了Sql命令对象的CommandText 

     

    5.SqlHelper类

    View Code
      1 using System;
      2 using System.Collections.Generic;
      3 using System.Linq;
      4 using System.Web;
      5 using System.Data;
      6 using System.Data.SqlClient;
      7 using System.Configuration;
      8 
      9 /// <summary>
     10 ///SqlHelper create by TerryChan 2012-04-17
     11 /// </summary>
     12 public class SqlHelper
     13 {
     14     #region 全局配置
     15     /// <summary>
     16     /// 连接字符串
     17     /// </summary> 
     18     public readonly static string connectionString = ConfigurationManager.ConnectionStrings["connstring"].ToString();
     19   
     20     /// <summary>
     21     /// SqlConnection对象
     22     /// </summary> 
     23     private static SqlConnection conn = new SqlConnection(connectionString);
     24 
     25     #endregion
     26 
     27     #region 打开数据库
     28     /// <summary>
     29     /// 打开数据库
     30     /// </summary>
     31     public static void OpenConnection()
     32     {
     33         if (conn.State != ConnectionState.Open)
     34         {
     35             try
     36             {
     37                 conn.Open();
     38             }
     39             catch (Exception ex)
     40             {
     41                 conn.Dispose();
     42                 throw new Exception("打开数据库失败!" + ex.Message);
     43             }
     44         }
     45     }
     46     #endregion
     47 
     48     #region 关闭数据库
     49     /// <summary>
     50     /// 关闭数据库
     51     /// </summary>
     52     public static void CloseConnection()
     53     {
     54         if (conn.State == ConnectionState.Open)
     55         {
     56             try
     57             {
     58                 conn.Close();
     59             }
     60             catch (Exception ex)
     61             {
     62                 conn.Dispose();
     63                 throw new Exception("关闭数据库失败!" + ex.Message);
     64             }
     65         }
     66     }
     67     #endregion
     68 
     69     #region ExecuteNoQuery 执行不返回数据行的操作,并返回一个int类型的数据
     70 
     71     /// <summary>
     72     /// 执行不返回数据行的操作,返回一个int类型的数据
     73     /// </summary>
     74     /// <param name="sql">要执行的SQL文本命令</param>
     75     /// <returns>返回受影响的行数</returns>
     76     public static int ExecuteNoQuery(string sql)
     77     {
     78         return ExecuteNoQuery(sql, CommandType.Text, null);
     79     }
     80 
     81     /// <summary>
     82     /// 执行不返回数据行的操作,返回一个int类型的数据
     83     /// </summary>
     84     /// <param name="sql">要执行的SQL文本命令或存储过程名称</param>
     85     /// <param name="type">要执行的查询语句的类型,存储过程或SQL文本命令</param>
     86     /// <returns>返回受影响的行数</returns>
     87     public static int ExecuteNoQuery(string sql, CommandType type)
     88     {
     89         return ExecuteNoQuery(sql, type, null);
     90     }
     91 
     92     /// <summary>
     93     /// 执行不返回数据行的操作,返回一个int类型的数据
     94     /// </summary>
     95     /// <param name="sql">要查询的SQL文本命令或存储过程名称</param>
     96     /// <param name="type">要执行的查询语句的类型,存储过程或SQL文本命令</param>
     97     /// <param name="sp">T-SQL语句或存储过程的参数数组</param>
     98     /// <returns>返回受影响的行数</returns>
     99     public static int ExecuteNoQuery(string sql, CommandType type, SqlParameter[] sp)
    100     {
    101         try
    102         {
    103             OpenConnection();
    104             SqlCommand command = new SqlCommand(sql, conn);
    105             command.CommandType = type;
    106             if (sp != null)
    107             {
    108                 foreach (SqlParameter parameter in sp)
    109                 {
    110                     command.Parameters.Add(parameter);
    111                 }
    112             }
    113             int result = command.ExecuteNonQuery();
    114             return result;
    115         }
    116         catch (Exception ex)
    117         {
    118             throw new Exception("ExecuteNoQuery错误:" + ex);
    119         }
    120         finally
    121         {
    122             CloseConnection();
    123         }
    124     }
    125 
    126     #endregion
    127 
    128     #region ExecuteScalar 执行查询,并返回查询结果集中第一行的第一列
    129 
    130         /// <summary>
    131         /// 执行查询结果,返回第一行的第一列
    132         /// </summary>
    133         /// <param name="sql">要执行的SQL文本命令</param>
    134         /// <returns>返回第一行的第一列</returns>
    135         public static object ExecuteScalar(string sql)
    136         {
    137             return ExecuteScalar(sql, CommandType.Text, null);
    138         }
    139 
    140         /// <summary>
    141         /// 执行查询结果,返回第一行的第一列
    142         /// </summary>
    143         /// <param name="sql">要查询的SQL文本命令或存储过程名称</param>
    144         /// <param name="type">要执行的查询语句的类型,存储过程或SQL文本命令</param>
    145         /// <returns>返回第一行的第一列</returns>
    146         public static object ExecuteScalar(string sql, CommandType type)
    147         {
    148             return ExecuteScalar(sql, type, null);
    149         }
    150 
    151         /// <summary>
    152         /// 执行查询结果,返回第一行的第一列
    153         /// </summary>
    154         /// <param name="sql">要查询的SQL文本命令或存储过程名称</param>
    155         /// <param name="type">要执行的查询语句的类型,存储过程或SQL文本命令</param>
    156         /// <param name="sp">T-SQL语句或存储过程的参数数组</param>
    157         /// <returns>返回第一行的第一列</returns>
    158         public static object ExecuteScalar(string sql,CommandType type,SqlParameter [] sp)
    159         {
    160             try
    161             {
    162                 object result = null;
    163                 OpenConnection();
    164                 SqlCommand command = new SqlCommand(sql,conn);
    165                 command.CommandType = type;
    166                 if (sp != null)
    167                 {
    168                     foreach (SqlParameter parameter in sp)
    169                     {
    170                         command.Parameters.Add(parameter);
    171                     }
    172                 }
    173                 result = command.ExecuteScalar();
    174                 return result;
    175             }
    176             catch (Exception ex)
    177             {
    178                 throw new Exception("ExecuteScalar错误:" + ex);
    179             }
    180             finally
    181             {
    182                 CloseConnection();
    183             }
    184         }
    185         #endregion
    186 
    187         #region ExecuteReader 执行查询,并返回一个 DataReader 对象
    188 
    189         /// <summary>
    190         /// 执行查询,并返回一个 DataReader 对象
    191         /// </summary>
    192         /// <param name="sql">要执行的SQL文本语句</param>
    193         /// <returns>返回DataReader对象实例</returns>
    194         public static SqlDataReader ExecuteReader(string sql)
    195         {
    196             return ExecuteReader(sql, CommandType.Text, null);
    197         }
    198 
    199         /// <summary>
    200         /// 执行查询,并返回一个 DataReader 对象
    201         /// </summary>
    202         /// <param name="sql">要查询的SQL文本命令或存储过程名称</param>
    203         /// <param name="type">要执行的查询语句的类型,存储过程或SQL文本命令</param>
    204         /// <returns>返回DataReader对象实例</returns>
    205         public static SqlDataReader ExecuteReader(string sql,CommandType type)
    206         {
    207             return ExecuteReader(sql, type, null);
    208         }
    209 
    210         /// <summary>
    211         /// 执行查询,并返回一个 DataReader 对象
    212         /// </summary>
    213         /// <param name="sql">要查询的SQL文本命令或存储过程名称</param>
    214         /// <param name="type">要执行的查询语句的类型,存储过程或SQL文本命令</param>
    215         /// <param name="sp">T-SQL语句或存储过程的参数数组</param>
    216         /// <returns>返回DataReader对象实例</returns>
    217         public static SqlDataReader ExecuteReader(string sql, CommandType type, SqlParameter[] sp)
    218         {
    219             try
    220             {
    221                 OpenConnection();
    222                 SqlCommand command = new SqlCommand(sql, conn);
    223                 command.Parameters.Clear();
    224                 if (sp != null)
    225                 {
    226                     foreach (SqlParameter parameter in sp)
    227                     {
    228                         command.Parameters.Add(parameter);
    229                     }
    230                 }
    231                 SqlDataReader reader = command.ExecuteReader();
    232                 return reader;
    233             }
    234             catch (Exception ex)
    235             {
    236                 throw new Exception("ExecuteReader错误:" + ex);
    237             }
    238             finally
    239             {
    240                 CloseConnection();
    241             }
    242         }
    243 
    244         #endregion
    245 
    246         #region ExecuteDataTable 执行查询,并返回结果集
    247 
    248         /// <summary>
    249         /// 执行查询,并返回结果集
    250         /// </summary>
    251         /// <param name="sql">要执行的SQL文本语句</param>
    252         /// <returns>查询结果集</returns>
    253         public static DataTable ExecuteDataTable(string sql)
    254         {
    255             return ExecuteDataTable(sql, CommandType.Text, null);
    256         }
    257 
    258         /// <summary>
    259         /// 执行查询,并返回结果集
    260         /// </summary>
    261         /// <param name="sql">要执行的SQL文本语句或存储过程</param>
    262         /// <param name="type">查询语句类型,存储过程或SQL文本命令</param>
    263         /// <returns>查询结果集</returns>
    264         public static DataTable ExecuteDataTable(string sql,CommandType type)
    265         {
    266             return ExecuteDataTable(sql, type, null);
    267         }
    268 
    269         /// <summary>
    270         /// 执行查询,并返回结果集
    271         /// </summary>
    272         /// <param name="sql">要执行的SQL文本语句或存储过程</param>
    273         /// <param name="type">查询语句类型,存储过程或SQL文本命令</param>
    274         /// <param name="sp">T-SQL语句或存储过程的参数组</param>
    275         /// <returns>查询结果集</returns>
    276         public static DataTable ExecuteDataTable(string sql,CommandType type,SqlParameter [] sp)
    277         {
    278             try
    279             {
    280                 DataTable dt = new DataTable();
    281                 SqlCommand command = new SqlCommand(sql,conn);
    282                 if (sp != null)
    283                 {
    284                     foreach (SqlParameter parameter in sp)
    285                     {
    286                         command.Parameters.Add(parameter);
    287                     }
    288                 }
    289                 SqlDataAdapter adapter = new SqlDataAdapter(command);
    290                 adapter.Fill(dt);
    291                 return dt;
    292             }
    293             catch (Exception ex)
    294             {
    295                 throw new Exception("ExecuteDataTable错误:" + ex);
    296             }
    297             finally
    298             {
    299                 CloseConnection();
    300             }
    301         }
    302         #endregion
    303     }
    304 }

     

     

    作者: ForEvErNoME
    出处: http://www.cnblogs.com/ForEvErNoME/
    欢迎转载或分享,但请务必声明文章出处。如果文章对您有帮助,希望你能 推荐关注
     
     
     
     
     
  • 相关阅读:
    Bete冲刺第二阶段
    Beta版本冲刺计划及安排
    Bete冲刺第一阶段
    软件工程实践总结
    用户试用体验报告
    Bata版本冲刺计划及安排
    scrum阶段总结
    关于 微软必应词典客户端 的案例分析
    第三次结对编程
    结对项目之需求分析与原型模型设计
  • 原文地址:https://www.cnblogs.com/ForEvErNoME/p/2517130.html
Copyright © 2011-2022 走看看