Spring.Net&NHibernate 学习 4

转载 2007年09月11日 16:30:00

第一个NHibernate 程序

任何熟悉Hibernate的人会发现这篇指南和Glen Smith A Hitchhiker's Guide to Hibernate 非常相近。这里的内容正是基于他的指南,因此所有的感谢都应该给与他。

 

NHibernate的文档并非每处都和Hibernate的文档一致。然而,项目的相似应该能使读者通过读Hibernate的文档来很好的理解NHibernate如何工作。

 

这篇文档意在让你尽可能快的开始使用NHibernate。它将介绍如何持久化一个简单的对象到一张表里。想得到更多的复杂的例子,可以参考NUnit测试及附带代码。

我们将进行以下步骤。

1.新建一个将要持久化.Net对象的表

2.构建一个可以让NHibernate知道如何持久化对象属性的映射文件

3.构建一个需要被持久化的.Net

4.构建一个存放NHibernater的配置文件的对像

5.使用NHibernateAPI测试你的第一个NHibernate程序

 

n        新建项目

项目名称为:NHibernateSample,名字空间:OKEC.Sample.NHibernate

n        建立数据表

数据库为SQLServer2000,表名为:my_users

if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[my_users]') and OBJECTPROPERTY(id, N'IsUserTable') = 1)

    drop table [dbo].[my_users]

    GO

    CREATE TABLE [dbo].[my_users] (

    [LogonId] [varchar] (50) COLLATE Chinese_PRC_CI_AS NOT NULL ,

    [UserName] [varchar] (50) COLLATE Chinese_PRC_CI_AS NULL ,

    [Password] [varchar] (50) COLLATE Chinese_PRC_CI_AS NULL ,

    [EmailAddress] [varchar] (50) COLLATE Chinese_PRC_CI_AS NULL ,

    [LastLogon] [datetime] NULL

    ) ON [PRIMARY]

    GO

    ALTER TABLE [dbo].[my_users] ADD

    CONSTRAINT [PK_my_users] PRIMARY KEY  CLUSTERED

    (

    [LogonId]

    )  ON [PRIMARY]

    GO

 

n        建立XML对像映射文件

现在我们有数据表和需要去映射它的.Net类。我们需要一种方式去让NHibernate知道如何从一个映射到另一个。这个任务依赖于映射文件来完成。最易于管理的办法是为每一个类写一个映射文件,如果你命名它是User.hbm.xml并且把它放在和类的同一个目录里,NHiberante将会使得事情简单起来。下面是User.hbm.xml的例子:

<?xml version="1.0" encoding="utf-8" ?>

<hibernate-mapping xmlns="urn:nhibernate-mapping-2.0">

    <class name=" OKEC.Sample.NHibernate.NHibernateTest.User,NHibernateSample" table="my_users">

        <id name="Id" column="LogonId" type="String" length="20">

        <generator class="assigned" />

        </id>       

        <property name="UserName" column="UserName" type="String" length="40"/>

        <property name="Password" column="Password" type="String" length="20"/>

        <property name="EmailAddress" column="EmailAddress" type="String" length="40"/>

        <property name="LastLogon" column="LastLogon" type="DateTime"/>

    </class>

</hibernate-mapping>

注意事项:在Visual Studio 2003/2005中要将此文件的属性设置为“嵌入的资源”(Embedded Resource

n        建立对像

对像定义:User.cs

using System;

namespace OKEC.Sample.NHibernate.NHibernateTest

{

    /// <summary>

    /// Summary description for User.

    /// </summary>

    public class User

    {

        private string id;

        private string userName;

        private string password;

        private string emailAddress;

        private DateTime lastLogon;

        public User()

        {

        }

        public string Id

        {

              get { return id; }

              set { id = value; }

        }

        public string UserName

        {

              get { return userName; }

              set { userName = value; }

        }

        public string Password

        {

              get { return password; }

              set { password = value; }

        }

        public string EmailAddress

        {

              get { return emailAddress; }

              set { emailAddress = value; }

        }

        public DateTime LastLogon

        {

              get { return lastLogon; }

              set { lastLogon = value; }

        }

    }

}

 

n        编写Nhibernate的初始化配置程序

程序名:MyConfiguration.cs

using System;

using NHibernate.Cfg;

namespace OKEC.Sample.NHibernate.NHibernateTest

{

    /// <summary>

    /// MyConfiguration 的摘要说明。

    /// </summary>

    public class MyConfiguration

    {

        public MyConfiguration()

        {

              //

              // TODO: 在此处添加构造函数逻辑

              //

        }

        public Configuration GetConfig()

        {

              try

              {

                  Configuration cfg = new Configuration();              cfg.SetProperty("hibernate.connection.provider","NHibernate.Connection.DriverConnectionProvider");

                  //请修改此行中的SQLServer的配置

                  cfg.SetProperty("hibernate.connection.connection_string","Data Source=192.168.88.15;Database=liluhua;User ID=sa;Password=sa;Trusted_Connection=False");

                  cfg.SetProperty("hibernate.dialect","NHibernate.Dialect.MsSql2000Dialect");

                  cfg.SetProperty("hibernate.connection.driver_class","NHibernate.Driver.SqlClientDriver");

                  cfg.AddAssembly("NHibernateSample");

                  return cfg;

              }

              catch(Exception ex)

              {

                  Console.WriteLine(ex.Message);

                  Console.WriteLine(ex.StackTrace);

              }

              return null;

        }

    }

}

n        编写调用程序

准备好上面的一切,我们就可以开始编辑启动程序,来测试你的第一个Nhibernate程序了。

程序名:UserFixture.cs

using System;

using System.Collections;

using NHibernate;

using NHibernate.Cfg;

using NHibernate.Expression;

namespace OKEC.Sample.NHibernate.NHibernateTest

{

    /// <summary>

    /// UserFixture 的摘要说明。

    /// </summary>

    public class UserFixture

    {

        public UserFixture()

        {

              //

              // TODO: 在此处添加构造函数逻辑

              //

        }

        public void ValidateQuickStart()

        {

              try

              {

                  //得到NHibernate的配置

                  MyConfiguration config = new MyConfiguration();

                  Configuration cfg = config.GetConfig();

 

                  ISessionFactory factory = cfg.BuildSessionFactory();

                  ISession session = factory.OpenSession();

                  ITransaction transaction = session.BeginTransaction();

 

                  User newUser = null;

                  try

                  {

                      newUser = (User)session.Load(typeof(User), "joe_cool");

                  }

                  catch

                  {

                  }

                  if(newUser==null)

                  {

                      newUser = new User();

                      newUser.Id = "joe_cool";

                      newUser.UserName = "Joseph Cool";

                      newUser.Password = "abc123";

                      newUser.EmailAddress = "joe@cool.com";

                      newUser.LastLogon = DateTime.Now;

 

                      // Tell NHibernate that this object should be saved

                      session.Save(newUser);

                  }           

 

                  // commit all of the changes to the DB and close the ISession

                  transaction.Commit();

                  session.Close();

 

                  // open another session to retrieve the just inserted user

                  session = factory.OpenSession();

 

                  User joeCool = (User)session.Load(typeof(User), "joe_cool");

 

                  // set Joe Cool's Last Login property

                  joeCool.LastLogon = DateTime.Now;

 

                  // flush the changes from the Session to the Database

                  session.Flush();

 

                  IList recentUsers = session.CreateCriteria(typeof(User))

                      .Add(Expression.Gt("LastLogon", new DateTime(2004, 03, 14, 20, 0, 0)))

                      .List();

                  foreach(User user in recentUsers)

                  {

                      //Assert.IsTrue(user.LastLogon > (new DateTime(2004, 03, 14, 20, 0, 0)) );

                      Console.WriteLine(user.UserName);

                      Console.WriteLine(user.Password);

                  }

                  session.Close();

              }

              catch(Exception ex)

              {

                  Console.WriteLine(ex.Message);

                  Console.WriteLine(ex.StackTrace);

              }

              Console.ReadLine();

        }

    }

}

n        测试你的程序

如果运行后没有出错,显示了结果,说明你的第一个NHibernate程序成功了。

Joseph Cool

abc123

 

 

Spring.Net&NHibernate 学习 5

创建数据库:NHibernate 创建表:my_usersCREATE TABLE [dbo].[my_users] (    [LogonId] [varchar] (50) COLLATE C...
  • ahywg
  • ahywg
  • 2007年09月13日 15:42
  • 1324

致各位虚幻4学习者

怎么说呢,能学虚幻4的人,能坚持下来学虚幻4的人,必定是对于游戏有无限的热忱,从内心里真正喜欢游戏的,没个学虚幻的人,可能都是抱着要做震惊世界的牛逼的游戏的想法,参与学习,每个虚幻开发者,必定是把游戏...
  • shangdi712
  • shangdi712
  • 2015年12月24日 11:48
  • 3527

Unreal Engine 4学习笔记:蓝图系统入门

蓝图系统是UE4提供的一套可视化编程工具,本文简单演示蓝图控制灯光的自动亮灭。 首先在场景中引入一个点光源,选中点光源,在上侧Toolbar中打开关卡蓝图: 在蓝图界面右键,对选中的点光源创建...
  • qq_31823267
  • qq_31823267
  • 2017年07月29日 15:17
  • 500

【虚幻4】学习总结3-蓝图入门2

这一次说一下类蓝图,上次说过,类蓝图就是把蓝图封装成一个类,然后调用它的方法就好,下面是一个类蓝图的示例,具体操作请看虚幻4的官方视频,英语不好没关系,可以先看操作,真的,可以          首...
  • shangdi712
  • shangdi712
  • 2015年12月27日 15:44
  • 2392

Metron学习3_Enhancing Metron Dashboard

Now that we have Metron configured to parse, index and persist telemetry events and Nifi pushing dat...
  • wang_zhenwei
  • wang_zhenwei
  • 2016年12月09日 16:50
  • 507

Spring4学习笔记----Spring的依赖注入详解

Spring是一个IOC和AOP容器,Spring是非侵入型的,基于Spring开发的web应用中的对象可以不依赖Spring的API. IOC:依赖注入 (让Spring Bean以配置文件的形式...
  • snow_7
  • snow_7
  • 2016年07月27日 20:47
  • 1572

【虚幻4】学习总结2-蓝图入门1

虚幻4的蓝图,其实是一种可视化编程,它是将一些东西封装成小框框,然后靠一条条线来链接起来,这个的好处就是很直观,给很多对写代码天生不感冒的人,提供了一种新的创造游戏的方法。         虚幻4的...
  • shangdi712
  • shangdi712
  • 2015年12月27日 15:15
  • 2457

caffe源码深入学习4:支持魔改的layer:layer.hpp与layer.cpp

到caffe源码深入学习3为止,我们解析了caffe底层的数据相关代码,了解了caffe这个深度学习框架中数据的存储与流通实现细节,那么,从本篇博客开始,笔者将开始解析更高层的代码,首先解析的是caf...
  • jiongnima
  • jiongnima
  • 2017年02月20日 21:26
  • 745

Spring4的学习(一)

1.首先在这里给大家分享一个很好的学习spring的资源一本书叫:Spring实战(美国的  Craig  Walls写的)特别好   推荐给大家看看!!! ①具体描述 Spring:       轻...
  • dq3wrr
  • dq3wrr
  • 2014年07月29日 15:50
  • 781

【Linux全面学习】4.Linux的目录结构

Linux的目录结构 (1)"/"目录 Linux文件系统的入口,也是出于最高一级的目录 (2)"/bin" 基础系统所需要的那些命令位于此目录。也是最小系统所需要命令;比如ls、cp、mkdir等...
  • u013517797
  • u013517797
  • 2016年07月18日 11:41
  • 585
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Spring.Net&NHibernate 学习 4
举报原因:
原因补充:

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