NHibernate.Linq e multicriterio
-
22-08-2019 - |
Domanda
Qualcuno sa di un modo per lotti query NHibernate utilizzando NHibernate.Linq come si può fare con multicriteria e ICriteria oggetti?
Con Multicriteri posso creare qualcosa di simile:
var crit = session.CreateMultiCriteria()
.Add(session.CreateCriteria(typeof(Entity1)).Add(Restrictions.Eq("Property1","Value"))
.Add(session.CreateCriteria(typeof(Entity2)).Add(Restrictions.Eq("Property2","Value2"));
var result = crit.List();
var list1 = (IList)result[0];
var list2 = (IList)result[1];
Sarebbe bello se si sostituisce la createCriteria chiamate con Linq chiama e ottenere qualcosa di simile a questo:
var crit = session.CreateMultiCriteria()
.Add(session.Linq<Entity1>().Where(x => x.Property1 == "Value1")
.Add(session.Linq<Entity2>().Where(x => x.Property2 == "Value2");
var result = crit.List();
var list1 = (IList<Entity1>)result[0];
var list2 = (IList<Entity2>)result[1];
Stiamo usando le API LINQ per la maggior parte delle nostre altre query e sarebbe bello usare la stessa sintassi LINQ quando abbiamo bisogno di correre multicriterio interroga pure.
Grazie.
Soluzione
var query = from q in session.Linq<Person>()
where q.FirstName.StartsWith(firstName)
&& q.LastName.StartsWith(lastName)
&& q.Phones.Any(p => p.Number.Contains(phone))
select q;
// This block of code was found in the NHibernate.Linq source
// using NHibernate.Linq.Visitors;
// using NHibernate.Engine;
System.Linq.Expressions.Expression expression = query.Expression;
expression = Evaluator.PartialEval(expression);
expression = new BinaryBooleanReducer().Visit(expression);
expression = new AssociationVisitor((ISessionFactoryImplementor)session.SessionFactory).Visit(expression);
expression = new InheritanceVisitor().Visit(expression);
expression = CollectionAliasVisitor.AssignCollectionAccessAliases(expression);
expression = new PropertyToMethodVisitor().Visit(expression);
expression = new BinaryExpressionOrderer().Visit(expression);
NHibernateQueryTranslator translator = new NHibernateQueryTranslator(session);
object results = translator.Translate(expression, ((INHibernateQueryable)query).QueryOptions);
// My LINQ query converted to ICriteria
ICriteria resultsCriteria = results as ICriteria;
// Convert to criteria that returns the row count
ICriteria rowCountCriteria = CriteriaTransformer.TransformToRowCount(resultsCriteria);
IList multiResults = session.CreateMultiCriteria()
.Add(resultsCriteria.SetMaxResults(20))
.Add(rowCountCriteria)
.List();
IList people = (IList)multiResults[0];
int resultsCount = (int)((IList)multiResults[1])[0];
http: //rndnext.blogspot. com / 2009/05 / usando-NHibernate-multicriteriale-e-linq.html
Altri suggerimenti
NHibernate.Linq stesso utilizza NHibernateQueryTranslator di tradurre dall'espressione LINQ a un ICriteria. Si potrebbe fare anche questo, quindi passare i ICriteria risultanti nelle vostre IMultiCriteria.
Ho una soluzione che consente sia di dosaggio a strategie di caricamento diretto usando NHibernate LINQ, ma il codice è il re del complesso. E 'troppo da elencare qui. Ho intenzione di parlare di sul mio blog su devlicio.us molto presto. Io aggiornerò questo commento quando scrivo il primo post.