在SQL Server中编写通用数据访问方法(3)

作者:doorsir 来源:赛迪网技术社区 时间:2009-01-20 11:35:00 

编写专门的数据访问层

因此,只使用基本接口不足以通过不同数据源提供可接受级别的抽象。这种情况下,一个好的解决方案是提高此抽象的级别,即创建一组类(如 Customer、Order 等)来封装特定数据提供程序的使用,并通过与特定数据源、类型化的“数据集”、对象集合等无关的数据结构与应用程序的其他级别交换信息。

可以在特定程序集内部创建此层的专用类(为每个受支持的数据源分别创建一个专用类),并可以在需要的情况下按照配置文件中的说明从应用程序加载它们。这样,如果您希望向应用程序中添加全新的数据源,唯一要做的事情是针对一组通用接口组中定义的“合同”实现一组新类。

让我们看一个实际例子:如果希望将 Microsoft? SQL Server? 和 Microsoft? Access 作为数据源为其提供支持,则应该在 Microsoft? Visual Studio? .NET 中创建两个不同项目,每个数据源分别创建一个。

为 SQL Server 创建的项目将类似于如下所示:

using System;
using System.Data;
using System.Data.Common;
using System.Data.SqlClient; 
using System.Configuration;   
using Common;

namespace DAL
{
   public class CustomersData : IDbCustomers
   {
      public DataTable GetCustomers()
      {
         string ConnectionString =
            ConfigurationSettings.AppSettings
            ["ConnectionString"];

         using (SqlConnection cnn = new SqlConnection
                  (ConnectionString))
         {
            string cmdString = "SELECT CustomerID," +
               "CompanyName,ContactName " +
               "FROM Customers";
            SqlCommand cmd =
               new SqlCommand (cmdString, cnn);

            SqlDataAdapter da = new SqlDataAdapter(cmd);

            DataTable dt = new DataTable("Customers");

            da.Fill(dt);

            return dt;
         }
      }
      public DataTable GetCustomerOrders(string CustomerID)
      {
         // 待定
         return null;
      }
      public DataTable GetCustomersByCountry
         (string CountryCode)
      {
         // 待定
         return null;
      }
      public bool InsertCustomer()
      {
         // 待定
         return false;
      }
   }
}

从 Microsoft? Access 进行数据检索的代码类似于如下所示:

using System;
using System.Data;
using System.Data.Common;
using System.Data.OleDb; 
using System.Configuration;   
using Common;

namespace DAL
{
   public class CustomersData : IDbCustomers
   {
      public DataTable GetCustomers()
      {
         string ConnectionString =
            ConfigurationSettings.AppSettings
            ["ConnectionString"];

         using (OleDbConnection cnn = new OleDbConnection
                  (ConnectionString))
         {
            string cmdString = "SELECT CustomerID," +
               "CompanyName,ContactName " +
               "FROM Customers";

            OleDbCommand cmd =
               new OleDbCommand (cmdString, cnn);

            OleDbDataAdapter da = new
               OleDbDataAdapter(cmd);

            DataTable dt = new DataTable("Customers");

            da.Fill(dt);

            return dt;
         }
      }
      public DataTable GetCustomerOrders(string CustomerID)
      {
         // 待定
         return null;
      }
      public DataTable GetCustomersByCountry
         (string CountryCode)
      {
         // 待定
         return null;
      }
      public bool InsertCustomer()
      {
         // 待定
         return false;
      }
   }
}

标签:
0
投稿

猜你喜欢

  • npm qs模块使用详解

    2024-04-25 13:11:14
  • Golang中结构体映射mapstructure库深入详解

    2024-04-26 17:34:40
  • Python 3中print函数的使用方法总结

    2021-12-21 00:37:18
  • 用openCV和Python 实现图片对比,并标识出不同点的方式

    2023-08-31 09:30:55
  • ASP对FoxPro自由表(DBF文件)的操作

    2010-05-27 12:20:00
  • Win7下Python与Tensorflow-CPU版开发环境的安装与配置过程

    2022-02-22 07:34:22
  • Django模板继承与模板的导入实例详解

    2023-04-03 14:41:28
  • 给Python学习者的文件读写指南(含基础与进阶)

    2021-04-26 12:05:40
  • SQL SERVER 与ACCESS、EXCEL的数据转换

    2024-01-18 04:24:40
  • MySQL单表多关键字模糊查询的实现方法

    2024-01-12 18:12:14
  • php支持中文字符串分割的函数

    2023-11-18 21:42:04
  • 浅析Oracle和Mysql分页的区别

    2024-01-26 19:03:59
  • Filestream使用简单步骤总结

    2024-01-24 08:08:26
  • Python获取当前时间的方法

    2022-06-11 18:24:03
  • Python自动生产表情包

    2022-04-13 05:25:36
  • Python GUI之tkinter详解

    2021-09-11 06:36:01
  • Vue中利用better-scroll组件实现横向滚动功能

    2024-05-09 15:28:29
  • golang开发go包依赖管理godep使用教程

    2023-10-16 04:09:31
  • python实现将html表格转换成CSV文件的方法

    2023-08-25 00:48:41
  • Python对HTML转义字符进行反转义的实现方法

    2022-07-27 08:44:34
  • asp之家 网络编程 m.aspxhome.com