我在C#中有一些Linq to SQL代码,我试图使用Matlab 2010b访问它。如果我的Linq代码返回单个项目实例,我可以在Matlab中无问题地访问所有属性:
dal = Data.PeopleRepository
person = dal.QueryPersonById(1)
person.Name
ans =
John Smith
但是,如果我调用一个返回IQueryable集合的Linq查询(实际上是一个System.Data.Linq.Table类),我很难找到里面的Person实例列表!
people = dal.QueryAllPeople()
people =
System.Data.Linq.Table<Data.Person> handle
Package: System.Data.Linq
Properties:
Context: [1x1 Data.PeopleRepository]
IsReadOnly: 0
我尝试过在人们身上使用GetEnumerator方法转换为IEnumerable,但我仍然无法获取内部的实际Person实例。 (我知道由于后期评估,实际上可能还没有从数据库中检索到这些值!Aarggh!)任何指针都表示赞赏,如果不清楚则道歉 - 这是我的第一个StackOverflow问题......
答案 0 :(得分:8)
今天遇到了类似的挑战。确实可以调用扩展方法。但是,语法有点笨拙。
为了枚举,IEnumerable.ToArray()扩展方法很方便。对于扩展方法,您需要知道它们的定义位置。在这种情况下,方法的完整签名是System.Linq.Enumerable.ToArray<T>(this IEnumerable<T>)
。 Matlab不关心this
修饰符。但是,因为它是泛型方法,所以不能在Matlab中直接使用它。相反,需要NET.invokeGeneric
方法。
以下示例枚举双精度数并将结果转换为Matlab数组。
ret = double(NET.invokeGenericMethod('System.Linq.Enumerable', 'ToArray', ...
{'System.Double'}, enumerableInstance));
从IQueryable<T> : IEnumerable<T>
开始,同样的方法(ToArray()
)应该可以完成你的工作。省略转换为Matlab双数组,并指定正确的元素类型(我想是Data.Person
)。
为了访问静态Enumerable类,Matlab需要加载.NET 3.0库。添加
NET.addAssembly('System.Core');
为此目的。
答案 1 :(得分:2)
我只是用Matlab和C#相反(从C#调用Matlab)但我觉得问题是你的代码中有一个IQueryable实例而不是IEnumerable。
尝试调用people = dal.QueryAllPeople().ToList()
或people = dal.QueryAllPeople.ToArray()
- 这些将导致执行查询 - 然后希望数据在Matlab中可用。
更新 - 因为扩展方法是禁止的......如果你尝试会发生什么:
myEnumerator = dal.QueryAllPeople().GetEnumerator()
myEnumerator.MoveNext()
firstItem = myEnumerator.Current
firstItem =
myEnumerator.MoveNext()
secondItem = myEnumerator.Current
secondItem =