草庐IT

查询优化

全部标签

c# - 查询 XmlDocument 而不会出现 'Namespace prefix is not defined' 问题

我有一个Xml文档,它定义并引用了一些命名空间。我将它加载到一个XmlDocument对象中,据我所知,我创建了一个XmlNamespaceManager对象,用于查询Xpath。问题是我收到XPath异常,表示命名空间“my”未定义。如何让命名空间管理器看到我引用的命名空间已经定义。或者更确切地说,如何将命名空间定义从文档获取到命名空间管理器。此外,令我感到奇怪的是,您必须首先为从文档命名表创建的文档提供命名空间管理器。即使您需要硬编码手动命名空间,为什么不能将它们直接添加到文档中。为什么每次查询都必须传递这个namespace管理器?XmlDocument不能知道什么?代码:Xml

c# - 允许 C# 编译器优化局部变量并从内存中重新获取值

编辑:我问的是当两个线程在没有适当同步的情况下同时访问相同数据时会发生什么(在这次编辑之前,这一点没有明确表达)。我对C#编译器和JIT编译器执行的优化有疑问。考虑以下简化示例:classExample{privateAction_action;privatevoidInvokeAction(){varlocal=this._action;if(local!=null){local();}}}请忽略示例中读取_action可能会产生缓存和过时的值,因为没有volatile说明符或任何其他同步。这不是重点:)是否允许编译器(或者实际上是运行时的抖动)优化对局部变量的赋值,而不是从内存中读

c# - 如何在 Nest ElasticSearch 客户端中编写日期范围查询?

我有一个.Net应用程序试图从elasticsearch文档存储中获取数据,具有以下结构的记录:{"_index":"TestIndex","_type":"amqp","_id":"123","_source":{"@timestamp":"2014-10-27T01:31:54.780Z","type":"amqp","LogGenerationTime":"2014-10-26T21:31:54.780","ThreadID":"6","ProcessID":"8136","SessionID":"xyz","UserID":"12345678",},}我想获取过去20分钟内具有

c# - 从 C# 运行时 SQL 查询超时,在 SQL Server Management Studio 中运行速度很快

我有一个使用下面列出的代码执行SQL查询的C#程序。直到前几天,我一直在使用这段代码一段时间,没有任何问题。我将一个查询字符串传递给SQL,其中包含一个字符串列表,这些字符串是股票标识符。前几天我跑了一下,查询超时了,让我跑一个多小时。过去几天我一直在尝试调试它。在我最初的查询中,大约有900个标识符。我已经尝试改变我能想到的一切,但我得到了无法解释的结果。例如:该查询适用于一个股票列表,但不适用于另一个在字符串数量和总长度方面具有相同长度的列表它适用于一个列表,但不适用于相反顺序的同一个列表对于一个列表,如果恰好有900个标识符,它就可以工作,但如果有899或901个,它就不会工作,

c# - 带有 IUserType 的 NHibernate linq 查询

在我的项目中,我使用IUserType(BooleanM1)来处理bool值并将-1表示为真,0表示为假值写入数据库。到目前为止一切正常。映射看起来像这个:所以如果我做如下查询varpList=Session.Query().Where(c=>c.Active).ToList();抛出异常:NHibernate.QueryException:Unabletorenderbooleanliteralvalue[.Where[Core.Test.Domain.Test](NHibernate.Linq.NhQueryable`1[Core.Test.Domain.Test],Quote((

c# - Microsoft Solver foundation 与 Matlab fmincon 中的约束非线性优化

任何人都可以向我展示MicrosoftSolverfoundation3.0中约束非线性优化的示例或评论吗?与Matlab的fmincon相比如何?或者是否有更好的.net库用于约束非线性优化?谢谢, 最佳答案 2012年2月25日的重要更新:MSF3.1现在通过其NelderMeadSolver求解器支持使用有界变量的非线性优化:http://msdn.microsoft.com/en-us/library/hh404037(v=vs.93).aspx对于一般的线性约束,Microsoftsolverfoundation仅通过其内

c# - 如何针对双核、四核和更高的多处理器进行优化?

伙计们,我从事高速软件编程已经20多年了,几乎了解书中的每一个技巧,从微平台制作合作、分析、用户模式多任务处理、尾递归,你可以用它来命名非常高性能的东西Linux、Windows等。问题是,当CPU密集型工作的多个线程暴露给多核处理器时,我发现自己对发生的事情感到困惑。线程之间(在不同内核上)共享数据的各种方式的微基准测试的性能结果似乎不符合逻辑。很明显,内核之间存在一些“隐藏的交互”,这在我自己的编程代码中并不明显。我听说过L1缓存和其他问题,但这些对我来说是不透明的。问题是:我在哪里可以学到这些东西?我正在寻找一本关于多核处理器如何工作、如何编程以利用其内存缓存或其他硬件架构而不是

c# - 使用单个 LINQ 查询使用 Entity Framework 删除多条记录

我正在尝试使用将生成单个查询的LINQ执行DELETE。这是我的做法://NorthwintEntitiesisanADO.NETEntitityDataModelvarnorthwindEntities=newNorthwindEntities();northwindEntities.Order_Details.Delete(o=>o.Order_ID==11076);这是我的扩展:publicstaticclassEntityExtensions{privatestaticRegexrxTableName=newRegex(@"^FROM\s+(?\[[^\]]*\](\.\[[^

c# - 在 Entity Framework 中组合表达式而不是使用多个查询

我有以下通用查询(可能已经应用了选择):IQueryablequeryable=DBSet.AsQueryable();然后是Provider类,如下所示:publicclassProvider{publicExpression>Condition{get;set;}[...]}Condition可以按以下方式为每个实例定义:Condition=entity=>entity.Id==3;现在我想选择所有Provider实例,这些实例的Condition至少被DBSet的一个实体满足:Listproviders=[...];varmatchingProviders=providers.W

c# - LINQ to Entities 查询不支持转换为十进制

我有一个数据库表Transaction(transactionID,LocalAmount...)。其中Localamount属性的数据类型是float。在UI上,我试图在按钮单击事件的一行中返回列(Localamount)的SUM。我使用了decimal而不是float但是,我在转换为decimal的代码中遇到错误System.NotSupportedExceptionwasunhandledbyusercodeMessage=CastingtoDecimalisnotsupportedinLINQtoEntitiesqueries,becausetherequiredprecisi