欢迎您访问我爱IT技术网,今天小编为你分享的编程技术是:【Asp.net多层架构中的变量引用与传递】,下面是详细的分享!
Asp.net多层架构中的变量引用与传递
Asp.net的多层架构主要是为了解决数据层,逻辑层,表示层等之间的关系。我的做法是这样的:首先建立一个DataCore的基类。基类里面封装了一些低层的数据库的基本操作,比如说数据库联接,调用存储过程等等。在这里面有一个地方值得注意,通过对一个函数的重载可以实现调用不同功能的存储过程。以下代码示例:
| 以下为引用的内容:
protected int RunProcedure(string storedProcName, IDataParameter[] parameters, out int rowsAffected ) int result; Connection.Open(); SqlCommand command=BuildIntCommand( storedProcName, parameters ); rowsAffected=command.ExecuteNonQuery(); result=(int)command.Parameters["ReturnValue"].Value; Connection.Close(); return result; } protected SqlDataReader RunProcedure(string storedProcName, IDataParameter[] parameters ) { SqlDataReader returnReader; Connection.Open(); SqlCommand command=BuildQueryCommand( storedProcName, parameters ); command.CommandType=CommandType.StoredProcedure; returnReader=command.ExecuteReader(); //Connection.Close(); return returnReader; } protected DataSet RunProcedure(string storedProcName, IDataParameter[] parameters, string tableName ) { DataSet dataSet=new DataSet(); Connection.Open(); SqlDataAdapter sqlDA=new SqlDataAdapter(); sqlDA.SelectCommand=BuildQueryCommand( storedProcName, parameters ); sqlDA.Fill( dataSet, tableName ); Connection.Close(); return dataSet; } protected void RunProcedure(string storedProcName, IDataParameter[] parameters, DataSet dataSet, string tableName ) { Connection.Open(); SqlDataAdapter sqlDA=new SqlDataAdapter(); sqlDA.SelectCommand=BuildIntCommand( storedProcName, parameters ); sqlDA.Fill( dataSet, tableName ); Connection.Close(); } |
道理很简单,一看就懂。对于以后的操作有好处的。
其次是要建立逻辑层,这个逻辑层基本上就是实例化数据层DataCore之后为表示层返回一些DataSet,DataReader之类或是执行一些insert,update,delete之类语句。这个逻辑层也是为了区分整个Project下面不同功能模块。比如说用户模块起名叫做UserModel.cs,新闻模块叫做NewsModel.cs之类。逻辑层的另一个好处就是可以为表示层建立可以多次实例化的同一个对象或是方法。比如说User类,通过ID或是Username 查询并建立的对象可以被表示层多次调用。
最后是表示层,表示层的功能就是完成页面逻辑。主要是接受客户端数据然后经过简单整合和判断,传递给逻辑层处理。同样,接收逻辑层传递来的Dataset或DataReader,表示在前台页面。
数据在各个层次之间的关系相对独立,但是又相对连续。
独立性:
对于表示层之外的几个层,都可以把单个的对象或是方法直接拿出来放到其他工程中。因为每个曾都是为了实现模型中独立的功能而完成的。因为在类似工程中的应用基本上不用太大改动,特别是一些相对更加原始的层,在这个示例中的DataCore就是一个典型的例子。
连续性:
数据在传递过程中有较强的连续性。举一个例子,在表示层中有这样一个根据Session中Userid返回一个Dataset,原本我是这样写的:
表示层:
DataSet UserInforRow=ObjectUser.GetUserInfor(Int32.Parse(Session["UserId"].ToString()));
逻辑层:
| 以下为引用的内容:
public DataSet GetUserInfor(int UserID) SqlParameter[] parameters={new SqlParameter("@UserID",SqlDbType.Int,4)}; parameters[0].Value=UserID; using(DataSet UserInfor=RunProcedure("GetUserInfor",parameters,"UserInfor")) { return UserInfor; } } |
这样可以编译通过,但是在执行的时候提示错误,类型不匹配,语法上面没有错误。但是错误出在,表示层传进来的是一个Int32,在Sqlparameter中确是一个Int,4,本来以为这样的变量类型都是在每一个层次中相对独立的,但是当他们之间传递数据的时候,出现了问题。
以上所分享的是关于Asp.net多层架构中的变量引用与传递,下面是编辑为你推荐的有价值的用户互动:
相关问题:ASP.NET页面之间传递值的几种方式
答:URL、Session、Cookies、Server.Transfer、Application和跨页面传送。 【分析】 本题考查面试者对ASP.NET中多页面传值的理解是否全面。因为ASP.NET的页面表单提交到自身,完成回传的功能,所以默认情况下不能使用POST方式进行多页面传值。关于这... >>详细
相关问题:在ASP.NET中,三层架构,Web ,BLL,DAL,Models这四个...
答:dal是数据库交互 bll是业务逻辑层 web就是我们的网页 model是元数据,model在所有层中用到。 其他别人又说,我不说了。 >>详细
相关问题:.Net 多层架构项目怎么发布呢?
答:一、三层架构 1.概述 使用多层应用程序结构,能使用户界面代码和业务逻辑代码分离,方便了应用程序中代码的修改,具有良好的解耦性。将业务逻辑集中到一个类库中,从而方便了开发和维护。在数据库数据的操作中,避免了代码的重复,提高了重用性... >>详细
- 评论列表(网友评论仅供网友表达个人看法,并不表明本站同意其观点或证实其描述)
-
