Spring.Net+NHibenate+Asp.Net mvc +ExtJs 系列 2

就以一个简单的DirectCenter项目开始介绍这个框架吧,DirectCenter主要分为用户管理,部门管理,公司管理三个模块。首先先搭建起解决方案DirectCenter:
DirectCenter:
DirectCenter.Model (类库项目)实体类库,其中包括hibernate映射文件(可以把映射文件放到DAL层,这样使Model也比较单纯,而DAL则只是Nhibernate的完整实现)
DirectCenter.IDAL (类库项目)数据访问层接口
DirectCenter.DAL (类库项目)数据库访问层实现(采用NHibernate)
DirectCenter.IBLL (类库项目)业务层接口
DirectCenter.BLL (类库项目)业务层实现(使用IDAL,通过spring.net的IOC注入实际的数据访问层)
DirectCenter.App (类库项目)系统的配置,其中包括Nhibernate,Spring.net的一些配置信息,业务层的DAL注入.
DirectCenter.UnitTest (类库项目) 使用nunit对业务层进行单元测试

DirectCenter.DTO (类库项目) data transform object 用于和前台UI层交互的实体。之所以分出来,也是为了考虑不只是为了Web项目,同时包括WebService等其它UI.(可能会有不少人会问已经有Model了,为什么还需要DTO?)

DirectCenter.Controllers (类库项目) Web控制器。用户请求和后台业务层的中转,接收并分析用户请求,调用业务层完成请求,再分发给用户。(注意这里调用的是IBLL,是业务逻辑接口,也是通过Spring.Net的IOC注入具体的业务实现)。
DirectCenter.Web (Web Application) 单纯的View层,主要由ExtJs完成界面和Ajax请求。

当然,这里也可以加一个Controllers的单元测试项目,不过我觉得这里很多时候用处不是很大。因为这里Controllers的工作比较统一和单纯了。
首先先设计和建立数据库,字段和说明如下:


数据库中没有外键关系,因为一对多,多对多这些关系使用NHibernate的持久层建立和维护,每个表中都有一个Version字段,这是为了使用Nhibernate内置的对象的版本控制来解决并发问题。
接下来的工作就简单了许多,因为今天我们只要完成实体就行,而实体类和映射文件的工作有一些辅助工具可以帮我们生成,比如codesmith, Nconstruct,Database2Sharp等,不过我还没有发现哪个工具能够很好的生成关系映射.这里只把User的类和映射文件放在这里,其 它的两个可以在源代码附件中找到。

User.cs
<!--<br><br>Code highlighting produced by Actipro CodeHighlighter (freeware)<br>http://www.CodeHighlighter.com/<br><br>-->usingSystem;
usingSystem.Collections.Generic;
usingSystem.Text;
usingSystem.Collections;

namespaceDirectCenter.Model
{


[Serializable]
publicclassUser
{
/**////<summary>
///创建日期
///</summary>

publicvirtualDateTimeCreateTime
{
get;
set;
}


/**////<summary>
///创建人
///</summary>

publicvirtualSystem.StringCreator
{
get;
set;
}




/**////<summary>
///Email地址
///</summary>

publicvirtualSystem.StringEmail
{
get;
set;
}


/**////<summary>
///用户编号
///</summary>
///

publicvirtualSystem.StringUserID
{
get;
set;
}


/**////<summary>
///导入日期
///</summary>

publicvirtualDateTime?ImportTime
{
get;
set;
}



/**////<summary>
///手机号码
///</summary>

publicvirtualSystem.StringMobile
{
get;
set;
}


/**////<summary>
///用户密码
///</summary>

publicvirtualSystem.StringPassword
{
get;
set;
}


/**////<summary>
///电话号码
///</summary>

publicvirtualSystem.StringTelephone
{
get;
set;
}


/**////<summary>
///用户名称
///</summary>

publicvirtualSystem.StringUserName
{
get;
set;
}


/**////<summary>
///生效日期
///</summary>

publicvirtualDateTime?ValidFrom
{
get;
set;
}



/**////<summary>
///失效日期
///</summary>

publicvirtualDateTime?ValidTo
{
get;
set;
}



/**////<summary>
///所属公司
///</summary>

publicvirtualCompanyCompany
{
get;
set;
}



/**////<summary>
///所属部门
///</summary>

publicvirtualDepartmentDepartment
{
get;
set;
}



/**////<summary>
///直接主管
///</summary>

publicvirtualUserManager
{
get;
set;
}


}

}


<!--<br><br>Code highlighting produced by Actipro CodeHighlighter (freeware)<br>http://www.CodeHighlighter.com/<br><br>--><?xmlversion="1.0"encoding="utf-8"?>
<hibernate-mappingxmlns="urn:nhibernate-mapping-2.2">

<classname="DirectCenter.Model.User,DirectCenter.Model"table="UserAccount"lazy="true">

<idname="UserID"column="UserID"type="System.String">
<generatorclass="assigned"/>
</id>

<propertyname="CreateTime"column="CreateTime"type="System.DateTime"/>
<propertyname="Creator"column="Creator"type="System.String"length="32"/>
<propertyname="Email"column="Email"type="System.String"length="255"/>

<propertyname="Mobile"column="Mobile"type="System.String"length="15"/>
<propertyname="Password"column="Password"type="System.String"length="64"/>
<propertyname="Telephone"column="Telephone"type="System.String"length="20"/>
<propertyname="UserName"column="UserName"not-null="true"type="System.String"length="32"/>
<propertyname="ValidFrom"column="ValidFrom"type="System.DateTime"/>
<propertyname="ValidTo"column="ValidTo"type="System.DateTime"/>


<!--用户所属交易公司-->
<many-to-onename="Company"
class
="DirectCenter.Model.Company,DirectCenter.Model"
cascade
="none"
column
="CompanyID"
/>

<!--用户所属部门-->
<many-to-onename="Department"
class
="DirectCenter.Model.Department,DirectCenter.Model"
cascade
="none"
column
="DepartmentID"
/>

<!--主管-->
<many-to-onename="Manager"
class
="DirectCenter.Model.User,DirectCenter.Model"
cascade
="none"
column
="ManagerID"
/>
</class>
</hibernate-mapping>

注:User的表名和实体名不一致的原因是因为User是数据库中的关键字。另外需要注意的是,映射文件中的命名空间要正确,映射文件(*.hbm.xml)不要忘了设置成Embedded Resource (嵌入式资源)。

数据库设计,实体,映射文件是使用这个框架开发最关键的,毕竟是转换需求的最重要的一步。如果设计的好的话,接下来的开发相对容易多了。下次介绍数据访问层和业务层的实现。

代码

你可能感兴趣的:(asp.net)