Linq to CRM - 无效操作异常

发布于 2024-11-28 01:36:53 字数 982 浏览 2 评论 0原文

我正在使用 MS CRM 4.0 的高级开发人员扩展中的 LINQ to CRM。它适用于直接查询。但当查询如下所示时,我遇到了一个问题:

var connectionString = @"User ID=u; Password=p; Authentication Type=AD; Server=http://crm:5555/UO";
var connection = CrmConnection.Parse(connectionString);
var dataContext = new CrmDataContext(connection);

var data = from u in dataContext.Accounts
           select new 
           {  
              Id = u.AccountID,
              Name = u.AccountName,
           };

var r = from n in data
        where n.Name.StartsWith("test")
        select new 
        { 
           Id = n.Id 
        };

r.Dump();

它抛出 InvalidOperationException“无法确定属性名称”。 当条件直接在第一个查询中时没关系:

var data = from n in dataContext.Accounts
           where n.AccountName.StartsWith("test")
           select new 
           {  
              Id = n.AccountID,
              Name = n.AccountName,
           };

我找不到有关此类错误的任何有用信息。这是 Xrm Linq Provider 中的错误吗? 预先感谢您的任何帮助。

I'm using a LINQ to CRM from Advanced Developer Extension for MS CRM 4.0. It works fine with direct queries. But I've got a problem when query looks like this:

var connectionString = @"User ID=u; Password=p; Authentication Type=AD; Server=http://crm:5555/UO";
var connection = CrmConnection.Parse(connectionString);
var dataContext = new CrmDataContext(connection);

var data = from u in dataContext.Accounts
           select new 
           {  
              Id = u.AccountID,
              Name = u.AccountName,
           };

var r = from n in data
        where n.Name.StartsWith("test")
        select new 
        { 
           Id = n.Id 
        };

r.Dump();

it throws an InvalidOperationException "Cannot determine the attribute name."
It's fine when a condition is directly in first query:

var data = from n in dataContext.Accounts
           where n.AccountName.StartsWith("test")
           select new 
           {  
              Id = n.AccountID,
              Name = n.AccountName,
           };

I cannot find any useful information about this kind of error. Is it a bug in Xrm Linq Provider?
Thanks in advance for any help.

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

一向肩并 2024-12-05 01:36:53

尝试使用 ToList() 预先加载初始查询,以便对匿名类型的后一个查询在本地进行评估。我知道如果您有很多帐户,这远非理想,但它会证明这一点。无论如何,您在最后一句话中基本上已经有了解决方案。

这是因为第一个查询根本不会执行,直到您调用 .Dump() ,此时整个表达式包括第二个查询被提供程序评估为一个(延迟执行),然后提供程序对于 Name 的属性。

Try eager loading the initial query with a ToList() so the latter query over your anonymous type is then evaluated locally. I get this is far from ideal if you have a lot of accounts but it'll prove the point. You essentially have a solution anyway in the last statement.

This is because the first query isn't executed at all until you call .Dump() at which point the entire expression including the second query is evaluated as one (deferred execution) by the provider which then looks for an attribute of Name.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文