科技行者

行者学院 转型私董会 科技行者专题报道 网红大战科技行者

知识库

知识库 安全导航

至顶网软件频道SQL Server数据库编写通用数据访问方法(6)

SQL Server数据库编写通用数据访问方法(6)

  • 扫一扫
    分享文章到微信

  • 扫一扫
    关注官方公众号
    至顶头条

在负责咨询工作的过去 6 年中,我曾多次听说关于数据访问和操作方面的问题,它时刻困扰着用户……

作者:010032 来源:赛迪网技术社区 2007年8月26日

关键字: 通用数据 SQL Server SQL Server 各版本 数据库

  • 评论
  • 分享微博
  • 分享邮件

从 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;
}
   }
}

CustomersData 类实现 IdbCustomers 接口。需要支持新数据源时,只能创建一个实现该接口的新类。

此类型的接口可以类似于如下所示:

using System;
using System.Data; 

namespace Common
{
    public interface IDbCustomers
    {
  DataTable GetCustomers();
  DataTable GetCustomerOrders(string CustomerID);
  DataTable GetCustomersByCountry(string CountryCode);
  bool InsertCustomer();
    }
}

我们可以创建专用程序集或共享程序集来封装这些数据访问类,在第一种情况下,程序集加载程序将搜索我们在 AppBase 文件夹的配置文件内指定的程序集,或者使用典型探测规则在子目录内进行搜索。如果我们必须与其他应用程序共享这些类,则可以将这些程序集置于全局程序集缓存中。

    • 评论
    • 分享微博
    • 分享邮件
    邮件订阅

    如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。

    重磅专题
    往期文章
    最新文章