📜  NHibernate-流利的Hibernate

📅  最后修改于: 2020-11-19 05:44:48             🧑  作者: Mango


在本章中,我们将介绍流利的NHibernate。流利的NHibernate是另一种映射方式,或者您可以说它是NHibernate的标准XML映射文件的替代方法。而不是编写XML (.hbm.xml文件)文档。借助Fluent NHibernate,您可以使用强类型的C#代码编写映射。

  • 在Fluent NHibernate中,映射与应用程序的其余部分一起被编译。

  • 您可以轻松地更改映射,就像您的应用程序代码一样,编译器在输入错误时也会失败。

  • 它具有常规的配置系统,您可以在其中指定用于覆盖命名约定和许多其他内容的模式。

  • 您还可以设置事物的命名方式,然后由Fluent NHibernate完成。

让我们通过创建一个新的控制台项目来查看一个简单的示例。在本章中,我们将使用一个简单的数据库,其中具有一个简单的Customer表,如下图所示。

简单的客户表

安装Fluent NHibernate

启动Fluent NHibernate的第一步是安装Fluent NHibernate软件包。因此,打开NuGet软件包管理器控制台,然后输入以下命令。

PM> install-package FluentNHibernate

成功安装后,您将看到以下消息。

已成功安装

让我们添加一个简单的Customer模型类,以下程序显示Customer类的实现。

using System; 
using System.Collections.Generic; 
using System.Linq;
using System.Text; 
using System.Threading.Tasks;

namespace FluentNHibernateDemo { 
   class Customer { 
      public virtual int Id { get; set; } 
      public virtual string FirstName { get; set; } 
      public virtual string LastName { get; set; } 
   } 
}

现在,我们需要使用流畅的NHibernate创建Mapping,因此在您的项目中再添加一个类CustomerMap 。这是CustomerMap类的实现。

using FluentNHibernate.Mapping; 
using System; 
using System.Collections.Generic; 
using System.Linq; using System.Text; 
using System.Threading.Tasks;

namespace FluentNHibernateDemo { 
   class CustomerMap : ClassMap { 
      public CustomerMap() { 
         Id(x => x.Id); 
         Map(x => x.FirstName); 
         Map(x => x.LastName); 
         Table("Customer"); 
      } 
   }
}

让我们添加另一个类NHibernateHelper,在其中我们将设置不同的配置设置。

using FluentNHibernate.Cfg; 
using FluentNHibernate.Cfg.Db; 
using NHibernate; 
using NHibernate.Tool.hbm2ddl;

namespace FluentNHibernateDemo { 

   public class NHibernateHelper { 
    
      private static ISessionFactory _sessionFactory;
        
      private static ISessionFactory SessionFactory { 
         get { 
            if (_sessionFactory == null)
            InitializeSessionFactory(); return _sessionFactory; 
         } 
      }
   
      private static void InitializeSessionFactory() { 
         _sessionFactory = Fluently.Configure() 
            
         String Data Source = asia13797\\sqlexpress;
         String Initial Catalog = NHibernateDemoDB;
         String Integrated Security = True;
         String Connect Timeout = 15;
         String Encrypt = False;
         String TrustServerCertificate = False;
         String ApplicationIntent = ReadWrite;
         String MultiSubnetFailover = False;
            
         .Database(MsSqlConfiguration.MsSql2008 .ConnectionString( 
            @"Data Source + Initial Catalog + Integrated Security + Connect Timeout
            + Encrypt + TrustServerCertificate + ApplicationIntent + 
            MultiSubnetFailover") .ShowSql() ) 
                
         .Mappings(m => m.FluentMappings
         .AddFromAssemblyOf()) 
         .ExposeConfiguration(cfg => new SchemaExport(cfg) 
         .Create(true, true)) 
         .BuildSessionFactory(); 
      }
        
      public static ISession OpenSession() { 
         return SessionFactory.OpenSession(); 
      } 
   }
}

现在,我们转到Program.cs文件,在该文件中我们将开始一个会话,然后创建一个新客户并将该客户保存到数据库中,如下所示。

using System; 
using System.Collections.Generic; 
using System.Linq; 
using System.Text; 
using System.Threading.Tasks;

namespace FluentNHibernateDemo { 
   class Program { 
    
      static void Main(string[] args) { 
        
         using (var session = NHibernateHelper.OpenSession()) { 
            
            using (var transaction = session.BeginTransaction()) { 
               var customer = new Customer { 
                  FirstName = "Allan", 
                  LastName = "Bomer" 
               }; 
                    
               session.Save(customer); 
               transaction.Commit();
               Console.WriteLine("Customer Created: " + customer.FirstName + "\t" +
                  customer.LastName); 
            } 
                
            Console.ReadKey(); 
         } 
      } 
   } 
}

让我们运行您的应用程序,您将看到以下输出。

if exists (select * from dbo.sysobjects where id = object_id(N'Customer') and
   OBJECTPROPERTY(id, N'IsUserTable') = 1) drop table Customer

create table Customer (
   Id INT IDENTITY NOT NULL,
   FirstName NVARCHAR(255) null,
   LastName NVARCHAR(255) null,
   primary key (Id)
)

NHibernate: INSERT INTO Customer (FirstName, LastName) VALUES (@p0, @p1); 
   select SCOPE_IDENTITY();@p0 = 'Allan' [Type: String (4000)], 
   @p1 = 'Bomer' [Type: String (4000)]
   Customer Created: Allan Bomer

如您所见,新客户已创建。要查看客户记录,让我们进入数据库并查看“查看数据”,您将看到已添加1个客户。

客户记录