日期:2014-02-06  浏览次数:20476 次

看了ASP.NET Time Tracker Starter Kit的代码以后,觉得这个程序是学习面向对象编程开发的一个好案例。整个程序从功能上来讲就是记录人员参加项目工作的工时记录。分析得出主要有人员、项目、工时记录这几个类。整个程序正好是以这几个类为基础展开的。在业务逻辑层里TTUser(用户类)、Project(项目类)和TimeEntry(工时记录类)分别就包括了对相应表的增、删、改等操作和整个程序中所用到的对这几个主要对象的各种操作。整个程序在类的划分和功能上做的很好,但是我觉得在三层架构的划分上不是很理想。 
业务逻辑层包含的许多数据访问层的东西,如:数据库连接信息、用到的存储过程等。而这些信息我觉得放在数据访问层应该会更好一些。作为数据访问层,应该为数据逻辑层提供访问数据库的方法,而不是只提供一个简化数据访问的组件(DAAB)。假设要使用Oracle数据,那么改动的代码就需要改动很多,同时也不利于将来的改动。 
我的想法是:彻底的将与数据相关的操作从数据逻辑层分离出去,对数据访问层只提供访问方法。在数据访问层的设计上,还是沿用“为数据访问层编写一个基类”的方法,通过基类访问DAAB。这样一来如果要变换为Oracle数据库,只要修改DAAB中的内容即可。大家帮忙看看我的改进代码,看看思路有无问题。
数据访问层基类:
using System;
using System.Data;
//数据访问组件(用的微软提供的)
using MyStarterKit.DDAB;
namespace MyStarterKit.TimeTracker.DAL
{
 /// <summary>
 /// DALBase 的摘要说明。
 /// 数据访问层积累
 /// </summary>
 public class DALBase
 {
  //数据库连接字符串
  private string CONNSTR = System.Configuration.ConfigurationSettings.AppSettings["ConnectionString"];
  public DALBase()
  {
  }
  /// <summary>
  /// 返回一个单值
  /// </summary>
  /// <param name="commandText"></param>
  /// <param name="parameterValues"></param>
  /// <returns></returns>
  protected object ExecuteScalar(string commandText, params object[] parameterValues)
  {
   return SqlHelper.ExecuteScalar(CONNSTR, commandText, parameterValues);
  }
  /// <summary>
  /// 执行无返回值操作
  /// </summary>
  /// <param name="commandText"></param>
  /// <param name="parameterValues"></param>
  protected void ExecuteNonQuery(string commandText, params object[] parameterValues)
  {
   SqlHelper.ExecuteNonQuery(CONNSTR, commandText, parameterValues);
  }
  /// <summary>
  /// 返回DataSet
  /// </summary>
  /// <param name="commandText"></param>
  /// <param name="parameterValues"></param>
  /// <returns></returns>
  protected DataSet ExecuteDataset(string commandText, params object[] parameterValues)
  {
   return SqlHelper.ExecuteDataset(CONNSTR, commandText, parameterValues);
  }
 }
}

数据访问层代码:(以项目类数据访问层代码为例)
using System;
using System.Data;
namespace MyStarterKit.TimeTracker.DAL
{
 /// <summary>
 /// Project 的摘要说明。
 /// 项目信息类(数据访问层代码)
 /// </summary>
 public class Project : DALBase
 {
  public Project()
  {
   //
   // TODO: 在此处添加构造函数逻辑
   //
  }
  /// <summary>
  /// 获取全部的项目列表
  /// </summary>
  /// <returns></returns>
  public DataSet GetAllProjects()
  {
   return base.ExecuteDataset("TT_ListAllProjects");
  }
  /// <summary>
 &n