В этой главе мы рассмотрим конфигурацию NHibernate. У нас есть разные способы настройки NHibernate. Он делится на две основные группы
- Конфигурация на основе XML
- Конфигурация на основе кода
Конфигурация на основе кода
Конфигурация на основе кода встроена в NHibernate. Он был представлен в NHibernate 3, и до сих пор мы использовали конфигурацию баз кода.
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; cfg.DataBaseIntegration(x = > { x.ConnectionString = "Data Source + Initial Catalog + Integrated Security + Connect Timeout + Encrypt + TrustServerCertificate + ApplicationIntent + MultiSubnetFailover"; x.Driver<SqlClientDriver>(); x.Dialect<MsSql2008Dialect>(); x.LogSqlInConsole = true; }); cfg.AddAssembly(Assembly.GetExecutingAssembly());
Все конфигурации указаны в коде C #. Здесь вы можете видеть, что у нас есть наш новый объект конфигурации, а затем мы используем простую конфигурацию, которая была представлена в NHibernate 3.1 для настройки базы данных. Какую строку подключения мы используем, к какой базе данных мы подключаемся и используемому диалекту. Мы также добавляем нашу картографическую сборку прямо сюда.
Конфигурация на основе XML
Если вы используете конфигурацию на основе XML, вы можете использовать файл hibernate.cfg.xml , который представляет собой просто отдельный xml-файл с использованием схемы NHibernate, или вы можете встроить эту конкретную конфигурацию NHibernate в свое приложение или web.cfg . Имя hibernate.cfg.xml по умолчанию, но мы также можем использовать произвольное имя для этого XML-файла.
Давайте посмотрим на конфигурацию на основе XML, добавив новый xml-файл в проект NHibernateDemoApp и назовем его hibernate.cfg.xml.
Введите следующую информацию в файл hibernate.cfg.xml.
<?xml version = "1.0" encoding = "utf-8" ?> <hibernate-configuration xmlns = "urn:nhibernate-configuration-2.2"> <session-factory> <property name = "connection.connection_string"> Data Source = asia13797\\sqlexpress; Initial Catalog = NHibernateDemoDB; Integrated Security = True; Connect Timeout = 15; Encrypt = False; TrustServerCertificate = False; ApplicationIntent = ReadWrite; MultiSubnetFailover = False; </property> <property name = "connection.driver_class"> NHibernate.Driver.SqlClientDriver </property> <property name = "dialect"> NHibernate.Dialect.MsSql2008Dialect </property> <mapping assembly = "NHibernateDemoApp"/> </session-factory> </hibernate-configuration>
Как вы можете видеть в приведенном выше XML-файле, мы указали ту же конфигурацию, что и в C #.
Теперь давайте прокомментируем эту конфигурацию из файла Program.cs и просто вызовем метод Configure () , который загрузит файл hibernate.cfg.xml, как показано ниже.
using HibernatingRhinos.Profiler.Appender.NHibernate;
using NHibernate.Cfg;
using NHibernate.Dialect;
using NHibernate.Driver;
using System;
using System.Linq;
using System.Reflection;
namespace NHibernateDemoApp {
class Program {
static void Main(string[] args) {
NHibernateProfiler.Initialize();
var cfg = new Configuration();
//cfg.DataBaseIntegration(x =>
//{
// x.ConnectionString = "Data Source = asia13797;\\sqlexpress
Initial Catalog = NHibernateDemoDB;
Integrated Security = True;
Connect Timeout = 15;
Encrypt =False;
TrustServerCertificate = False;
ApplicationIntent = ReadWrite;
MultiSubnetFailover = False";
// x.Driver<SqlClientDriver>();
// x.Dialect<MsSql2008Dialect>();
// x.LogSqlInConsole = true;
//});
//cfg.AddAssembly(Assembly.GetExecutingAssembly());
cfg.Configure();
var sefact = cfg.BuildSessionFactory();
using (var session = sefact.OpenSession()) {
using (var tx = session.BeginTransaction()) {
var students = session.CreateCriteria<Student>().List<Student>();
Console.WriteLine("\nFetch the complete list again\n");
foreach (var student in students) {
Console.WriteLine("{0} \t{1} \t{2} \t{3}", student.ID,
student.FirstName, student.LastName, student.AcademicStanding);
}
tx.Commit();
}
Console.ReadLine();
}
}
}
}
Давайте снова запустим ваше приложение, и вы увидите тот же результат.