Метод AddQueries будет реализован следующим образом, чтобы «исправить» отсутствие поддержки Loader в Fluent NHibernate.Хитрость заключается в том, чтобы правильно настроить значение INativeSQLQueryReturn [], чтобы оно содержало отображение столбцов таблицы на свойства сущности.Он должен имитировать содержимое возвращаемого элемента sql-запроса в файле HBM, где определены класс (с пространством имен) и сопоставления свойств (см. XML ниже).Спасибо @jimbobmcgee за то, что я начал работать в этом направлении!
private static void AddQueries(Configuration cfg)
{
var namedQuery = new NamedSQLQueryDefinition(
"exec dbo.pr_GETCustomers @CustomerID=?",
new INativeSQLQueryReturn[]
{
new NativeSQLQueryRootReturn(
"Customers",
"VehicleInfo.Entities.Customers",
new Dictionary<string, string[]>
{
{"CustomerID", new[] {"CustomerID"}},
{"CompanyName", new[] {"CompanyName"}}
},
LockMode.Read)
},
new List<string> { "dbo.Customers" },
true,
null,
15,
1000,
FlushMode.Auto,
CacheMode.Normal,
false,
"",
null,
true);
cfg.NamedSQLQueries.Add("pr_GETCustomers", namedQuery);
var cust = cfg.GetClassMapping(typeof(Customers));
cust.LoaderName = "pr_GETCustomers";
}
Образец файла HBM, который делает то же самое:
<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2"
default-access="property" auto-import="true"
default-cascade="none" default-lazy="true">
<class xmlns="urn:nhibernate-mapping-2.2"
mutable="true" name="VehicleInfo.Entities.Customers, VehicleInfo, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null" table="Customers">
<id name="CustomerID" type="System.String, mscorlib, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089">
<column name="CustomerID" />
<generator class="assigned" />
</id>
<property name="CompanyName" type="System.String, mscorlib, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089">
<column name="CompanyName" />
</property>
<loader query-ref="pr_GETCustomers"/>
<sql-insert callable="true" check="none">exec dbo.pr_INSERTCustomers @CompanyName=?, @CustomerID=?</sql-insert>
<sql-update callable="true" check="none">exec dbo.pr_UPDATECustomers @CompanyName=?, @CustomerID=?</sql-update>
<sql-delete callable="true" check="none">exec dbo.pr_DELETECustomers @CustomerID=?</sql-delete>
</class>
<sql-query name="pr_GETCustomers">
<return alias="cust" class="VehicleInfo.Entities.Customers, VehicleInfo, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null">
<return-property name="CustomerID" column="CustomerID"></return-property>
<return-property name="CompanyName" column="CompanyName"></return-property>
</return>
exec dbo.pr_GETCustomers @CustomerID=?
</sql-query>
</hibernate-mapping>