Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/linq/3.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
LINQ+;WCF&x2B;交易_Linq_Wcf_Transactions_Freeze - Fatal编程技术网

LINQ+;WCF&x2B;交易

LINQ+;WCF&x2B;交易,linq,wcf,transactions,freeze,Linq,Wcf,Transactions,Freeze,我有一个相对简单的用例,它失败了。考虑下面的代码: [OperationBehavior(TransactionScopeRequired = true)] public IEnumerable<StatusRecord> ReadActive(int contactID, bool isActive) { var result = from n in ORM.Default.Table<StatusRecord>() where n.

我有一个相对简单的用例,它失败了。考虑下面的代码:

[OperationBehavior(TransactionScopeRequired = true)]
public IEnumerable<StatusRecord> ReadActive(int contactID, bool isActive)
{
  var result = from n in ORM.Default.Table<StatusRecord>()
                where n.lng_contact_id == contactID && n.dte_effective_end == null
                select n;

  return result;
}


让事情顺利进行。虽然我很高兴有一个解决办法,但似乎有一个更好的方法来实现这一点。请告知。谢谢大家!

不要在WCF操作中使用差异执行。您必须在返回结果之前执行查询-这就是您在result.ToArray()中所做的

在将查询返回到WCF客户机之前,您肯定想实现(ToList()/ToArray()等)?我明白您的意思,但是如果没有事务,延迟执行就可以了。WCF自动展平/序列化/具体化(无论正确的词是什么)枚举-希望我在这里也能做到这一点。
return result;
return result.ToArray();