Further Linq enhancements
No edit summary |
(Automatically adding template at the end of the page.) |
||
(5 intermediate revisions by 3 users not shown) | |||
Line 1: | Line 1: | ||
Until now, it has been problematic to filter on type in Linq. | |||
This model shows the problem: | |||
[[File:Linq.png|none|thumb|366x366px]] | |||
If you want to find SomeSubClass that has a Class2 with a specific name:<html> | |||
If you want to find SomeSubClass that has a Class2 with a specific name : | |||
<html> | |||
<pre class="code"><span style="background: white; color: blue;">var </span><span style="background: white; color: black;">foo2 = (</span><span style="background: white; color: blue;">from </span><span style="background: white; color: black;">v </span><span style="background: white; color: blue;">in </span><span style="background: white; color: #2b91af;">EcoLinqExtender</span><span style="background: white; color: black;">.PSQuery<</span><span style="background: white; color: #2b91af;">Class2</span><span style="background: white; color: black;">>(EcoSpace) | <pre class="code"><span style="background: white; color: blue;">var </span><span style="background: white; color: black;">foo2 = (</span><span style="background: white; color: blue;">from </span><span style="background: white; color: black;">v </span><span style="background: white; color: blue;">in </span><span style="background: white; color: #2b91af;">EcoLinqExtender</span><span style="background: white; color: black;">.PSQuery<</span><span style="background: white; color: #2b91af;">Class2</span><span style="background: white; color: black;">>(EcoSpace) | ||
</span><span style="background: white; color: blue;">where </span><span style="background: white; color: black;">(v.Class1.Attribute1 == </span><span style="background: white; color: #a31515;">"5" </span><span style="background: white; color: black;">&& v.Name == </span><span style="background: white; color: #a31515;">"5A"</span><span style="background: white; color: black;">) | </span><span style="background: white; color: blue;">where </span><span style="background: white; color: black;">(v.Class1.Attribute1 == </span><span style="background: white; color: #a31515;">"5" </span><span style="background: white; color: black;">&& v.Name == </span><span style="background: white; color: #a31515;">"5A"</span><span style="background: white; color: black;">) | ||
Line 14: | Line 11: | ||
</html> | </html> | ||
But now you also get | But now, you also get Class1s that are not of SomeSubClass.That is a problem in certain situations. | ||
In Ocl2Ps we would have done: | In Ocl2Ps, we would have done: | ||
''Class2.allInstances->select(a|((a.Class1.Attribute1 = '5') and (a.Name = '5A'))).Class1->FilterOnType(SomeSubClass)'' | |||
Until now, MDriven Linq2Sql logic did not understand the Linq counterpart of FilterOnType – which is OfType<class>(). | |||
But now it does: | But now it does: | ||
Line 27: | Line 26: | ||
</html> | </html> | ||
With this | With this in place, the database takes care of all the filtering for us and returns the SomeSubClasses that have any Class2 with the correct criteria. | ||
[[Category:Linq]] | |||
{{Edited|July|12|2024}} |
Latest revision as of 15:34, 10 February 2024
Until now, it has been problematic to filter on type in Linq.
This model shows the problem:
If you want to find SomeSubClass that has a Class2 with a specific name:
var foo2 = (from v in EcoLinqExtender.PSQuery<Class2>(EcoSpace) where (v.Class1.Attribute1 == "5" && v.Name == "5A") select v.Class1)
But now, you also get Class1s that are not of SomeSubClass.That is a problem in certain situations.
In Ocl2Ps, we would have done:
Class2.allInstances->select(a|((a.Class1.Attribute1 = '5') and (a.Name = '5A'))).Class1->FilterOnType(SomeSubClass)
Until now, MDriven Linq2Sql logic did not understand the Linq counterpart of FilterOnType – which is OfType<class>().
But now it does:
var foo2 = (from v in EcoLinqExtender.PSQuery<Class2>(EcoSpace) where (v.Class1.Attribute1 == "5" && v.Name == "5A") select v.Class1).OfType<SomeSubClass>()
With this in place, the database takes care of all the filtering for us and returns the SomeSubClasses that have any Class2 with the correct criteria.
This page was edited more than 11 months ago on 02/10/2024. What links here