□ отсутствие в LINQ для сущностей поддержки методов Single
и singleOrDefault
, вместо которых рекомендуется использовать First
и FirstOrDefault
;
□ вместо методов DeleteOnSubmit
и SubmitChanges
в LINQ для сущностей предложены методы DeleteObject
и saveChanges
соответственно;
□ вместо метода XXX.InsertOnSubmit
предложены обертки (автогенерируемые) AddToXXX
, где XXX — это имя отображаемой сущности (таблицы).
Еще одно незначительное отличие в процессе автогенерации моделей с помощью мастеров в Visual Studio представляет собой изменение имени таблицы при отображении на класс в LINQ для SQL. Например, таблица Customers
отобразится на класс Customer
, без последней буквы "s". При создании классов в Entity Framework мастер не производит такие изменения.
Еще одним вариантом организации доступа к данным может стать популярная ORM-библиотека NHibernate — довольно старый механизм, портированный на платформу .NET Framework из Java-проекта Hibernate. Как ORM, Hibernate давно заслужила право называться зрелой, гибкой, мощной и главное производительной библиотекой. Адаптация под .NET, хотя и не совсем полностью реализует функционал Hibernate версии 3, но предлагает все тот же механизм, сравнимый по мощности и производительности с предком.
NHibernate, как и другие ORM, использует для реализации доступа к данным мэппинг в виде XML-файла. Этот файл должен быть оформлен согласно схеме nhibernate-mapping.xsd, которая идет в комплекте поставки. По традиции названия всех таких файлов мэппинга формируются как class_name.hbm.xml. Такой файл может выглядеть примерно так:
namespace="MyNamespace" assembly="MyNamespace">
Здесь создается мэппинг класса Customer
на таблицу Customers
в базе данных, которая содержит ряд полей: customerId, name, phone, address
. Для подключения к базе данных должен быть создан другой конфигурационный файл, похожий на этот:
NHibernate.Connection.DriverConnectionProvider
NHibernate.Driver.SqlClientDriver
NHibernate.Dialect.MsSql2005Dialect
Server=(local);
Initial Catalog=MyDatabase;
Integrated Security=SSPI;
assembly="MyNamespace" />
К сожалению, для NHibernate отсутствует встроенная автоматизация генерации отображаемого кода и модели данных, а также файлов конфигурации. Поэтому описание модели ложится на плечи разработчика. С одной стороны, это рутинные операции, которые машина сделает лучше, но с другой, такой подход предоставляет разработчику больший простор для реализации его идей. Впрочем, в Интернете есть проекты с открытым исходным кодом, призванные облегчить и этот и другие процессы при работе с NHibernate:
□ Fluent NHibernate (http://fluentNHibernate.org/);
□ MyGeneration (http://www.mygenerationsoftware.com/portal/default.aspx);
□ NHibernate 1.2 Generator (http://gennit.com/);
□ NHibernate Query Generator
(http://ayende.com/projects/downloads/NHibernate-query-generator.aspx);
□ NHibernate Entity Generator (http://www.softpedia.com/get/Programming/Other-Programming-Files/NHibernate-Entity-Generator.shtml);
□ NHibernate Helper Kit (http://www.codeproject.com/KB/dotnet/NHibernate_Helper_Kit.aspx);
□ многие другие (http://stackoverflow.com/questions/41752/nhibernate-generators).
Для работы с NHibernate используются пространства имен NHibernate и NHibernate.Cfg . Второе служит для загрузки файла конфигурации, например, как показано в следующем примере:
ISessionFactory sessionFactory = new Configuration()
.Configure("Nhibernate.cfg.xml").BuildSessionFactory();
где Nhibernate.cfg.xml
— ваш файл конфигурации.
NHibernate основывается на объектах ISession
, которые представляют собой пользовательскую сессию подключения к базе данных, поэтому для работы с данными необходимо создать экземпляр ISession
. В качестве примера работы с NHibernate можно привести такой шаблон кода:
ISession session;
ITransaction tran;
try
{
session = sessionFactory.OpenSession();
tran = session.BeginTransaction();
// делаем какую-то работу
tran.Commit();
session.Close();
}
catch (Exception ex)
{
tran.Rollback();
session.Close();
}
Как вы можете заметить, NHibernate реализует механизм транзакций с возможностью откатывать ненужные изменения.
Работа с объектами NHibernate возможна с помощью одного из трех вариантов:
□ Hibernate Query Language (HQL) — языка во многом похожего на язык LINQ c SQL-синтаксисом;
□ Query By Criteria (QBC) — объектный вариант, который позволяет строить выражения запросов динамически через объектно-ориентированный API;
□ через обыкновенные SQL-запросы.
Приведем простой пример использования HQL:
string result = (string)session.createQuery(@"select phone
from Customer as c
where c.name = 'Сергей Иванов'").UniqueResult();
Пример вернет телефон заказчика по его имени. Перепишем этот пример с использованием Query By Criteria:
Читать дальше
Конец ознакомительного отрывка
Купить книгу