的多层架构主要是为了解决数据层逻辑层表示层等之间的关系我的做法是这样的首先建立一个DataCore的基类基类里面封装了一些低层的数据库的基本操作比如说数据库联接调用存储过程等等在这里面有一个地方值得注意通过对一个函数的重载可以实现调用不同功能的存储过程以下代码示例
protected int RunProcedure(string storedProcName IDataParameter[] parameters out int
rowsAffected )
{
int result;
ConnectionOpen();
SqlCommand command = BuildIntCommand( storedProcName parameters );
rowsAffected = commandExecuteNonQuery();
result = (int)commandParameters[ReturnValue]Value;
ConnectionClose();
return result;
}
protected SqlDataReader RunProcedure(string storedProcName IDataParameter[] parameters )
{
SqlDataReader returnReader;
ConnectionOpen();
SqlCommand command = BuildQueryCommand( storedProcName parameters );
commandCommandType = CommandTypeStoredProcedure;
returnReader = commandExecuteReader();
//ConnectionClose();
return returnReader;
}
protected DataSet RunProcedure(string storedProcName IDataParameter[] parameters
string tableName )
{
DataSet dataSet = new DataSet();
ConnectionOpen();
SqlDataAdapter sqlDA = new SqlDataAdapter();
sqlDASelectCommand = BuildQueryCommand( storedProcName parameters );
sqlDAFill( dataSet tableName );
ConnectionClose();
return dataSet;
}
protected void RunProcedure(string storedProcName IDataParameter[] parameters
DataSet dataSet string tableName )
{
ConnectionOpen();
SqlDataAdapter sqlDA = new SqlDataAdapter();
sqlDASelectCommand = BuildIntCommand( storedProcName parameters );
sqlDAFill( dataSet tableName );
ConnectionClose();
道理很简单一看就懂对于以后的操作有好处的
其次是要建立逻辑层这个逻辑层基本上就是实例化数据层DataCore之后为表示层返回一些DataSetDataReader之类或是执行一些insertupdatedelete之类语句这个逻辑层也是为了区分整个Project下面不同功能模块比如说用户模块起名叫做UserModelcs新闻模块叫做NewsModelcs之类逻辑层的另一个好处就是可以为表示层建立可以多次实例化的同一个对象或是方法比如说User类通过ID或是Username 查询并建立的对象可以被表示层多次调用
最后是表示层表示层的功能就是完成页面逻辑主要是接受客户端数据然后经过简单整合和判断传递给逻辑层处理同样接收逻辑层传递来的Dataset或DataReader表示在前台页面
数据在各个层次之间的关系相对独立但是又相对连续
独立性
对于表示层之外的几个层都可以把单个的对象或是方法直接拿出来放到其他工程中因为每个曾都是为了实现模型中独立的功能而完成的因为在类似工程中的应用基本上不用太大改动特别是一些相对更加原始的层在这个示例中的DataCore就是一个典型的例子
连续性
数据在传递过程中有较强的连续性举一个例子在表示层中有这样一个根据Session中Userid返回一个Dataset原本我是这样写的:
表示层
DataSet UserInforRow = ObjectUserGetUserInfor(IntParse(Session[UserId]ToString()));
逻辑层
public DataSet GetUserInfor(int UserID)
{
SqlParameter[] parameters ={new SqlParameter(@UserIDSqlDbTypeInt)};
parameters[]Value = UserID;
using(DataSet UserInfor = RunProcedure(GetUserInforparametersUserInfor))
{
return UserInfor;
}
这样可以编译通过但是在执行的时候提示错误类型不匹配语法上面没有错误
但是错误出在表示层传进来的是一个Int在Sqlparameter中确是一个Int本来以为这样的变量类型都是在每一个层次中相对独立的但是当他们之间传递数据的时候出现了问题
对于这个问题的解决方案有两种无非是更改表示层还是更改逻辑层更改逻辑层就要改成
SqlParameter[] parameters ={new SqlParameter(@UserIDSqlDbTypeInt)};
更改表示层要改为
DataSet UserInforRow = ObjectUserGetUserInfor(intParse(Session[UserId]ToString()));
两个方案中显然是更改表示层比较合理因为不能够因为一个变量的传递更改变逻辑层中的可以被其他表示层页面所调用的方法
其他类似的变量传递和引用也遇到类似问题虽然几个层次相对独立但是在数据的传递上也相对连续