Asp.net MVC 2 + Castle + NHibernate 项目实战(1)

简介:

本文将开始一步一步地使用Asp.net MVC 2 + Castle + NHibernate 开发一个项目。

 

在开始之前,我先对这三个组件做一个简单的介绍:

 Asp.net MVC 

它是微软提供的一个基于MVC标准的Web开发模式,其典型特点是有控制器和视图;在这之前,.NET下的Web开发模式大多是采用WebForm,其典型特点是服务端控件和后台触发事件; 

 NHibernate

它是一个ORM框架,使用Java的SSH做过项目开发的人就非常熟悉了,当前最新版本为NHibernate 3.0,听说完全支持Linq查询语句了,以前只支持HQL语句。 

 Castle

它是一个非常大的框架,包含IoC、MVC、ORM、AOP等,这次我只用到其IoC的功能。

 

关于IoC

IoC的英文是Inversion of Control,中文意思是控制反转,也有称其为Dependence Injection,中文意思是依赖注入,也就是DI;

除了Castle可以作IoC 外,还有著名的Spring.Net、Unity等,在我另外一个开源博客项目 http://rorowo.codeplex.com/ 中就用到了微软的Unity 2.0作为IoC。

 

好了,废话不多说,下面开始。 

 

首先,第一步是创建一个解决方案,项目结构如下:

 

需要引用的DLL库文件,我们全部放在RoRoWo.Common.DependLib下:

 

 根据表的结构,如图: 

 

 

现在我们开始为表结构创建实体类,以BlogCategory表为例,我们根据该表的字段名称和数据类型创建一个POCO类,放在RoRoWo.Domain.Entities下,代码内容如下:

 代码

namespace  RoRoWo.Domain {
    
    
public   class  Blogcategory {
        
public  Blogcategory() { }
        
public   virtual   int  Cateid {  get set ; }
        
public   virtual  IList < Blogarticle >  Blogarticles {  get set ; }
        
public   virtual   string  Catename {  get set ; }
        
public   virtual   int  Parentid {  get set ; }
        
public   virtual   int  State {  get set ; }
        
public   virtual   int  Sortid {  get set ; }
        
public   virtual   int  Articlecount {  get set ; }
        
public   virtual  System.DateTime Createtime {  get set ; }
        
public   virtual   string  Note {  get set ; }
    }
}

 

 在这里,我推荐一个可以生成NHibernate映射对象代码的工具(开源的),项目地址:NHibernate Mapping Generator(它同时支持 hbm.xml文件的方式、Fluent Mapping方式、Castle ActiveRecord方式)

接下来,要为这个类创建一个映射关系,我这里使用配置文件的方式,但是正式项目推荐使用Fluent方式。我们创建一个XML文件,文件名为“Blogcategory.hbm.xml”,放在RoRoWo.Domain.Mappings下,内容如下:

代码
<? xml version = " 1.0 "  encoding = " utf-8 " ?>
< hibernate - mapping assembly = " RoRoWo.Domain "   namespace = " RoRoWo.Domain "  xmlns = " urn:nhibernate-mapping-2.2 "   default - lazy = " false " >
    
< class  name = " Blogcategory "  table = " BlogCategory " >
        
< id name = " Cateid "  column = " CateID " >
            
< generator  class = " native "   />
        
</ id >
        
< property name = " Catename "  column = " CateName "   />
        
< property name = " Parentid "  column = " ParentID "   />
        
< property name = " State "  column = " State "   />
        
< property name = " Sortid "  column = " SortID "   />
        
< property name = " Articlecount "  column = " ArticleCount "   />
        
< property name = " Createtime "  column = " CreateTime "   />
        
< property name = " Note "  column = " Note "   />
    
</ class >
</ hibernate - mapping >

 

 

这里就是一个典型的映射关系了,如果有一对多,多对多的表关系,也是在这个配置中进行维护。

创建这个XML后,还有个很重要的操作,就是将其设为“嵌入的资源” ,鼠标右键查看“Blogcategory.hbm.xml”文件属性,将“生成操作”项的“内容”改为“嵌入的资源”,如图:

 

 到此,一个映射关系的实体就建立好了,下面我们就要来实现NHibernate对该表的增删改查操作了,我们把这些操作的实现放在RoRoWo.Data中。

注意,RoRoWo.Data需要添加对 “Castle.Core.dll”  " Castle.DynamicProxy2.dll "   " NHibernate.dll "   " RoRoWo.Domain "  的引用。

 

在创建数据库操作类之前,我们需要创建一个 “SessionManager”类,它负责维护整个ORM中的上下文,这里我使用李永京的一个类,其代码如下:

代码
using  System;
using  System.Collections.Generic;
using  System.Linq;
using  System.Text;

using  NHibernate;
using  NHibernate.Cfg;

namespace  RoRoWo.Data
{
    
public   class  SessionManager
    {
        
private  ISessionFactory _sessionFactory;
        
public  SessionManager()
        {
            _sessionFactory  =  GetSessionFactory();
        }
        
private  ISessionFactory GetSessionFactory()
        {
            
return  ( new  Configuration()).Configure().BuildSessionFactory();
        }
        
public  ISession GetSession()
        {
            
return  _sessionFactory.OpenSession();
        }
    }
}

 

 

我们创建一个“BlogCategoryRespository.cs”文件,其代码如下:

代码

 

 

该代码具有了对一个表的基本操作,现在我们就来创建一个单元测试,测试一下插入数据。

在创建插入操作时,我们要能使NHibernate正常工作,还需要创建一个配置文件,我们创建一个XML文件,文件名为“hibernate.cfg.xml”,放在RoRoWo.UnitTest下,其内容为:

代码
<? xml version="1.0" encoding="utf-8" ?>
< hibernate-configuration   xmlns ="urn:nhibernate-configuration-2.2"   >
    
< session-factory >
        
< property  name ="connection.driver_class" > NHibernate.Driver.SqlClientDriver </ property >
        
< property  name ="connection.connection_string" >
            Data Source=.;Initial Catalog=RoRoWoDB;User ID=sa;Password=2010;
        
</ property >
        
< property  name ="adonet.batch_size" > 10 </ property >
        
< property  name ="show_sql" > true </ property >
        
< property  name ="dialect" > NHibernate.Dialect.MsSql2005Dialect </ property >
        
< property  name ="use_outer_join" > true </ property >
        
< property  name ="command_timeout" > 10 </ property >
        
< property  name ="query.substitutions" > true 1, false 0, yes 'Y', no 'N' </ property >
        
< property  name ="proxyfactory.factory_class" >
            NHibernate.ByteCode.Castle.ProxyFactoryFactory,
            NHibernate.ByteCode.Castle
        
</ property >
        
< mapping  assembly ="RoRoWo.Domain" />
    
</ session-factory >
</ hibernate-configuration >

 

 其中“Data Source=.;Initial Catalog=RoRoWoDB;User ID=sa;Password=2010;”是我的数据库连接,您可以改为您的。

 

现在我们添加一个单元测试(不明白如何添加的请参考相关资料),先测试插入方法,其代码如下:

 代码

         ///   <summary>
        
/// Create 的测试
        
/// </summary>
        [TestMethod()]
        
public   void  CreateTest()
        {
            SessionManager sessionManager  =   new  SessionManager();
            ISession session  =  sessionManager.GetSession();
            BlogCategoryRespository target  =   new  BlogCategoryRespository(session);
            Blogcategory dto  =   new  Blogcategory();

            dto.Catename  =   " 新分类 "   +   new  Random().Next( 100000 999999 ).ToString();
            dto.Parentid  =   0 ;
            dto.State  =   0 ;
            dto.Createtime  =  DateTime.Now;

            
int  newid  =  target.CreateAndReturn(dto);
            Assert.IsTrue(newid  >   0 );
        }

 

 执行单元测试,可以通过测试,并且在数据库中已经成功插入了一条记录,结果完全正确;

我们接着对查询方法进行测试,我们将测试代码如下:

代码

 

 

 测试结果全部绿灯通过:

 

下一篇,我将谈谈如何配置一对多和多对多的表映射关系。

 

该例子的完整代码可以到开源平台下载,地址: http://rorowoproject.codeplex.com

文章中如有不足之处,望大家多指正。

 




本文转自远哥博客园博客,原文链接:http://www.cnblogs.com/taven/archive/2010/09/28/1837478.html,如需转载请自行联系原作者

相关文章
|
1月前
|
SQL XML 关系型数据库
入门指南:利用NHibernate简化.NET应用程序的数据访问
【10月更文挑战第13天】NHibernate是一个面向.NET的开源对象关系映射(ORM)工具,它提供了从数据库表到应用程序中的对象之间的映射。通过使用NHibernate,开发者可以专注于业务逻辑和领域模型的设计,而无需直接编写复杂的SQL语句来处理数据持久化问题。NHibernate支持多种数据库,并且具有高度的灵活性和可扩展性。
40 2
|
2月前
|
开发框架 前端开发 JavaScript
ASP.NET MVC 教程
ASP.NET 是一个使用 HTML、CSS、JavaScript 和服务器脚本创建网页和网站的开发框架。
43 7
|
2月前
|
存储 开发框架 前端开发
ASP.NET MVC 迅速集成 SignalR
ASP.NET MVC 迅速集成 SignalR
60 0
|
3月前
|
开发框架 前端开发 .NET
ASP.NET MVC WebApi 接口返回 JOSN 日期格式化 date format
ASP.NET MVC WebApi 接口返回 JOSN 日期格式化 date format
49 0
|
3月前
|
开发框架 前端开发 安全
ASP.NET MVC 如何使用 Form Authentication?
ASP.NET MVC 如何使用 Form Authentication?
|
3月前
|
开发框架 .NET
Asp.Net Core 使用X.PagedList.Mvc.Core分页 & 搜索
Asp.Net Core 使用X.PagedList.Mvc.Core分页 & 搜索
127 0
|
6月前
|
开发框架 前端开发 .NET
ASP.NET CORE 3.1 MVC“指定的网络名不再可用\企图在不存在的网络连接上进行操作”的问题解决过程
ASP.NET CORE 3.1 MVC“指定的网络名不再可用\企图在不存在的网络连接上进行操作”的问题解决过程
194 0
|
6月前
|
开发框架 前端开发 JavaScript
JavaScript云LIS系统源码ASP.NET CORE 3.1 MVC + SQLserver + Redis医院实验室信息系统源码 医院云LIS系统源码
实验室信息系统(Laboratory Information System,缩写LIS)是一类用来处理实验室过程信息的软件,云LIS系统围绕临床,云LIS系统将与云HIS系统建立起高度的业务整合,以体现“以病人为中心”的设计理念,优化就诊流程,方便患者就医。
81 0
|
6月前
|
开发框架 前端开发 .NET
C# .NET面试系列六:ASP.NET MVC
<h2>ASP.NET MVC #### 1. MVC 中的 TempData\ViewBag\ViewData 区别? 在ASP.NET MVC中,TempData、ViewBag 和 ViewData 都是用于在控制器和视图之间传递数据的机制,但它们有一些区别。 <b>TempData:</b> 1、生命周期 ```c# TempData 的生命周期是短暂的,数据只在当前请求和下一次请求之间有效。一旦数据被读取,它就会被标记为已读,下一次请求时就会被清除。 ``` 2、用途 ```c# 主要用于在两个动作之间传递数据,例如在一个动作中设置 TempData,然后在重定向到另
347 5
|
6月前
|
开发框架 前端开发 .NET
进入ASP .net mvc的世界
进入ASP .net mvc的世界