搭建你的Spring.Net+Nhibernate+Asp.Net Mvc 框架 (三)实现数据库接口层和业务逻辑层(转)

转载 2012年05月03日 12:07:36

本篇是介绍我们完成数据库接口层和业务逻辑层的接口的设计和实现。

废话不多讲,还是怎么一步一步做。

第一步:设计IDao层。在MyWeb.WebTemp.IDao项目中添加IUserDao接口。代码如下:

代码 

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using MyWeb.WebTemp.Model;

namespace MyWeb.WebTemp.IDao
{
    public interface IUserDao
    {
        /// <summary>
        /// 获取所有的用户
        /// </summary>
        /// <returns></returns>
        IList<User> GetAllUsers();

        /// <summary>
        /// 根据id来获取用户
        /// </summary>
        /// <param name="Id"></param>
        /// <returns></returns>
        User GetUserById(int Id);

        /// <summary>
        /// 添加用户信息
        /// </summary>
        /// <param name="user"></param>
        /// <returns></returns>
        bool AddUser(User user);

        /// <summary>
        /// 更新用户信息
        /// </summary>
        /// <param name="user"></param>
        /// <returns></returns>
        bool UpdateUser(User user);

        /// <summary>
        /// 更新或者添加用户信息
        /// </summary>
        /// <param name="user"></param>
        /// <returns></returns>
        bool AddOrUpdateUser(User user);

        /// <summary>
        /// 删除用户
        /// </summary>
        /// <param name="user"></param>
        /// <returns></returns>
        bool DeleteUser(User user);
    }
}


注:要添加Model项目的引用。因为我们用到了User实体类。

第二步:实现IDao设计。在MyWeb.WebTemp.HibernateDao项目中添加类文件:UserDaoHibernate.cs

在编写代码之前,我们首先要引入spring.net和Nhibernate的支持类库。我用到的所有dll,稍后将提供下载。如果你急需

可以通过邮件向我索取:malun666@126.com

另外要添加Model项目的引用。因为我们也用到了实体类。

代码如下:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using Spring.Data.NHibernate.Generic.Support;
using Spring.Data.NHibernate.Generic;
using SpringHiberate.dao.model;
using NHibernate;
using MyWeb.WebTemp.IDao;

namespace MyWeb.WebTemp.HibernateDao
{
    public class UserDaoHibernate : HibernateDaoSupport,IUserDao
    {
         #region IUserDao 成员
       
        public IList<MyWeb.WebTemp.Model.User> GetAllUsers()
        {
            return HibernateTemplate.LoadAll<MyWeb.WebTemp.Model.User>();             
        }

        public MyWeb.WebTemp.Model.User GetUserById(int Id)
        {
            return (MyWeb.WebTemp.Model.User)HibernateTemplate.Execute(new HibernateDelegate<MyWeb.WebTemp.Model.User>(delegate(NHibernate.ISession session)
            {
                StringBuilder sb = new StringBuilder();
                sb.Append("from User c  where c.Id=?");
                IQuery query = session.CreateQuery(sb.ToString());
                query.SetParameter(0, Id);
                return query.UniqueResult() as MyWeb.WebTemp.Model.User;
            }), true);
        }

        public bool AddUser(MyWeb.WebTemp.Model.User user)
        {
            if (HibernateTemplate.Save(user) != null)
            {
                return true;
            }
            return false;
        }

        public bool UpdateUser(MyWeb.WebTemp.Model.User user)
        {
            HibernateTemplate.Update(user);
            return true;
        }

        public bool AddOrUpdateUser(MyWeb.WebTemp.Model.User user)
        {
            HibernateTemplate.SaveOrUpdate(user);
            return true;
        }

        public bool DeleteUser(MyWeb.WebTemp.Model.User user)
        {
            HibernateTemplate.Delete(user);
            return true;
        }

        #endregion
    }
}


这就实现了数据库接口层的基本的增删改。具体看你的应用,可以根据你的需要添加。

第三步:设计接口IBLL层【业务逻辑接口层】。在MyWeb.WebTemp.IBLL中添加类文件:IUserService

注:添加Model项目的引用。因为这一层我们用到了User实体类。还是看代码:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using MyWeb.WebTemp.Model;

namespace MyWeb.WebTemp.IBLL
{
    public interface IUserService
    {
        /// <summary>
        /// 获取 所有用户信息列表
        /// </summary>
        /// <returns></returns>
        IList<User> GetAllUsers();

        /// <summary>
        /// 保存用户信息
        /// </summary>
        /// <param name="user"></param>
        /// <returns></returns>
        bool UpdateUser(User user);

        /// <summary>
        /// 删除用户信息
        /// </summary>
        /// <param name="user"></param>
        /// <returns></returns>
        bool DeleteUser(User user);

        /// <summary>
        /// 添加一个用户信息
        /// </summary>
        /// <param name="user"></param>
        /// <returns></returns>
        bool AddUser(User user);

        /// <summary>
        /// 添加或者更新用户信息
        /// </summary>
        /// <param name="user"></param>
        /// <returns></returns>
        bool UpdateOrAddUser(User user);

        /// <summary>
        /// 根据id来获取用户信息
        /// </summary>
        /// <param name="id"></param>
        /// <returns></returns>
        User GetUserById(int id);
    }
}


第四步:实现IBLL层。【业务逻辑接口的实现】在MyWeb.WebTemp.BLL中添加类文件:UserServiceImpl.cs

注:Impl是实现单词的缩写。同样我们要添加Model项目引用和IUserDao项目的引用。看代码:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using MyWeb.WebTemp.IBLL;
using MyWeb.WebTemp.IDao;
using MyWeb.WebTemp.Model;

namespace MyWeb.WebTemp.BLL
{
    public class UserServiceImpl : IUserService
    {
        #region 属性

        private IUserDao userDao;

        public IUserDao UserDao
        {
            get { return userDao; }
            set { userDao = value; }
        }
        
        #endregion

        #region IUserService 成员

        public IList<User> GetAllUsers()
        {
            return UserDao.GetAllUsers();
        }

        public bool UpdateUser(User user)
        {
            return UserDao.UpdateUser(user);
        }

        public bool DeleteUser(User user)
        {
            return UserDao.DeleteUser(user);
        }

        public bool AddUser(User user)
        {
            return UserDao.AddUser(user);
        }

        public bool UpdateOrAddUser(User user)
        {
            return UserDao.AddOrUpdateUser(user);
        }

        public User GetUserById(int id)
        {
            return UserDao.GetUserById(id);
        }

        #endregion
    }
}


当前项目的目录结构如图所示:

你的业务逻辑层和数据库接口层实现了吗?

先写到这。呵呵,先回家吃饭去了。呵呵

原文网址:http://www.cnblogs.com/fly_dragon/archive/2010/09/06/1819547.html

相关文章推荐

搭建你的Spring.Net+Nhibernate+Asp.Net Mvc 框架 (二)创建你的项目(转)

本篇文章的目的:首先是创建解决方案。并创建相关的项目。先介绍一下项目的各自的作用: 从数据库层到表示层依次为: 数据库层:    1、接口IDao层:IDao    2、Dao层实现:Hi...

搭建你的Spring.Net+Nhibernate+Asp.Net Mvc 框架 (五)测试你的成果(转)

本篇文章:主要介绍怎么使用这套框架。在做好配置等前期工作后。我们就是要与Mvc进行融合了。由于Mvc本人也是个初级入门者。对于这部分的研究还不是很深入。但是基本应用已经可以了。下面就让我们开始一个简单...

ASP.NET MVC4 中整合 NHibernate3.3、Spring.NET2.0、ExtJS4 笔记二:开发环境搭建

一、相关的下载地址 微软的东西一般都比较方便,主要是因为微软把很多东西都做成了傻瓜式的,即使你不懂也有完整的文档。就如最基本的软件安装一样,很少用到使用命令行操作的,只要一步一步next就完成了...
  • xz2001
  • xz2001
  • 2013年03月04日 09:53
  • 2491

开源框架完美组合之Spring.NET + NHibernate + ASP.NET MVC + jQuery + easyUI 中英文双语言小型企业网站Demo

代码下载热衷于开源框架探索的我发现ASP.NET MVC与jQuery easyUI的组合很给力。由于原先一直受Ext JS框架的licence所苦恼,于是痛下决心寻找一个完全免费的js框架——eas...

整合asp.net mvc4,Spring.net,nhibernate实现分层开发

1,在web.config配置中添加如下配置信息,同时指定Spring.net的核心配置文件services.xml和Objects.xml。 --> ...

ASP.NET MVC4 中整合 NHibernate3.3、Spring.NET2.0、ExtJS4 笔记一:简介

本人做了6年多的.NET开发,之前很少使用一些成型的企业级框架,很是遗憾。2个月前,经朋友介绍到一家java公司,公司从事业务系统开发,内部有成型的业务框架,属于ssh的二次开发。 在刚去公司的一段...
  • xz2001
  • xz2001
  • 2012年12月30日 10:29
  • 3813

ASP.NET MVC4 中整合 NHibernate3.3、Spring.NET2.0、ExtJS4 笔记三:NHibernate配置

目前NHibernate的最新版是3.3.2,官方下载地址:http://sourceforge.net/projects/nhibernate/files/NHibernate/ 下载后解压N...
  • xz2001
  • xz2001
  • 2012年12月30日 15:26
  • 3266
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:搭建你的Spring.Net+Nhibernate+Asp.Net Mvc 框架 (三)实现数据库接口层和业务逻辑层(转)
举报原因:
原因补充:

(最多只允许输入30个字)