草庐IT

sql语句SQLServer

全部标签

C#锁定SQL Server表的方法

我有一个C#程序需要对SQLServer表执行一组批量更新(20k+)。由于其他用户可以通过Intranet网站一次更新这些记录,因此我们需要构建具有锁定表功能的C#程序。一旦表被锁定以防止其他用户进行任何更改/搜索,我们将需要执行请求的更新/插入。由于我们要处理如此多的记录,我们不能使用TransactionScope(起初似乎是最简单的方法),因为我们的交易最终由MSDTCservice处理.我们需要使用另一种方法。根据我在Internet上阅读的内容,使用SqlTransaction对象似乎是最好的方法,但是我无法锁定表。当程序运行并且我单步执行下面的代码时,我仍然能够通过内部网

c# - 将嵌套的 for 循环转换为单个 LINQ 语句

有人可以帮我把这个嵌套结构变成单个LINQ语句吗?EventLog[]logs=EventLog.GetEventLogs();for(inti=0;i 最佳答案 嵌套循环通常以多个“from”子句结束(编译器将其转换为对SelectMany的调用):varremoteAccessLogs=fromloginEventLogs.GetEventLogs()wherelog.LogDisplayName=="AAA"fromentryinlog.Entrieswhereentry.Source=="BBB"selectentry;(假

c# - Linq To SQL 附加/刷新实体对象

在LinqToSql中,更新我的一个实体Faculty时,我正在创建Faculty对象的一个​​新实例,然后使用用户提供的值初始化一些属性。p>如果我将这个新对象附加到实体集并提交更改,则我未设置的属性将采用它们是任何数据类型的默认值。如何刷新新对象,使已设置的属性保留其值,而未设置的属性从数据库中获取值?谢谢 最佳答案 你试过吗context.Refresh(RefreshMode.OverwriteCurrentValues,faculty);提交更改后,context是您的linq2sql数据上下文,faculty是您要刷新的

c# - 使用 LINQ-to-SQL 处理 where 子句中的空值

VisualStudio中的LINQ-to-SQL查询生成一个有错误的SQL查询。在LINQPad中,使用相同数据库(或DataContext)的相同LINQ查询运行得很好。LINQ查询varaccesDomaines=fromtindb.Accesswheret.IdUser==access.IdUtilisateurwheret.IdDomain!=nullwheret.IdRole==access.IdRolewheret.IdPlace==access.IdPlaceselectt;下面是生成的SQL中发生错误的一小部分:WHERE(...)AND([t3].[IdRole]=

c# - lock() 语句会阻塞进程/应用程序域中的所有线程吗?

也许这个问题听起来很愚蠢,但我不明白“关于线程和锁定的一些事情,我想得到确认(here'swhyIask)”。因此,如果我有10台服务器并且同时有10个请求到达每个服务器,那么整个服务器场就有100个请求。如果没有锁定,那就是对数据库的100个请求。如果我这样做:privatestaticreadonlyobjectmyLockHolder=newobject();if(Cache[key]==null){lock(myLockHolder){if(Cache[key]==null){Cache[key]=LengthyDatabaseCall();}}}我将执行多少数据库请求?10?

c# - SQL 性能、.Net 优化与最佳实践

我需要专业人士/大师的确认/解释如下,因为我的团队告诉我“没关系”,这让我很沮丧:)背景:我们有一个SQLServer2008,我们的主MVC3/.Net4Web应用程序正在使用它。在任何给定点,我们都有大约200多个并发用户。服务器受到了极大的打击(锁定、超时、整体缓慢),我正在尝试应用我在整个职业生涯中以及在上一次MS认证类(class)中学到的东西。它们是我们一直在钻研的东西(“关闭SQL连接STAT”),我试图向我的团队解释这些“小东西”,虽然不是单独一个就能产生影响,但最终会加起来。我需要知道以下内容是否会对性能产生影响,或者这只是“最佳实践”1.使用“USING”关键字。他

c# - 从 ASP.NET 与 SQL Mgmt Admin 调用时存储过程速度较慢

我们正在尝试诊断复杂存储过程中的缓慢(它有几个巨大的查询)。当我们从ASP.NET调用SP时,需要5秒。当我们从SQLManagementStudio调用它时(仅使用EXEC),它需要0.05秒。我们已经在许多不同的方式和环境中一致地测试了这种行为。这是针对C#.NET的。数据库为MSSQLServer2012。问题出在Web应用程序上,但我们编写了一个小型控制台应用程序作为测试工具,并且行为是相同的。1)我们在C#.NET控制台应用程序中计算耗时,如下所示:stopwatch.Start();rdr=cmd.ExecuteReader();stopwatch.Stop();2)我们通

c# - 返回具有 id == 某物的元素的行号的 LINQ 语句?

如何编写返回id==元素的ROWNUMBER的LINQ语句? 最佳答案 据我所知,没有直接的方法可以做到这一点。您必须将整个查询下拉到客户端,然后您可以从那里转换行号。作为替代方案,您可以编写一个使用ROW_NUMBER的存储过程,然后从LinqtoSQL命中该过程。在您的情况下,您能够做到这一点的唯一方法是客户端。请记住,以下语句不会在服务器上执行此操作,但会拉下整个表并在客户端获取索引...using(vardc=newDataClasses1DataContext()){varresult=dc.Users.AsEnumera

c# - Visual Studio 2008 中的 If 语句异常

我遇到了一个非常奇怪的问题,我记录了我的session,因为我认为没有人会相信我。我遇到了一个似乎非常基础的错误。这是一个单线程应用程序,我所做的只是计算一个bool值。bool值等于false,但是,if语句正在执行,就好像它是true...有点。你会明白我的意思。我已经清理了解决方案并重建了很多次。不知道发生了什么。请给我一些解释。http://www.youtube.com/watch?v=ope9kxEyt4g 最佳答案 我以前见过很多次。基本上发生的事情是您正在调试的代码与您看到的代码不匹配。我不知道是什么原因造成的,解决

c# - 在 Linq-To-Sql 中避免 "Nullable object must have a value."

我有一个这样的方法查询:publicIListGetBusinessObject(Guid?filterId){using(vardb=newL2SDataContext()){varresult=fromboindb.BusinessObjectswhere(filterId.HasValue)?bo.Filter==filterId.value:trueorderbybo.NameselectSqlModelConverters.ConvertBusinessObject(bo);returnresult.ToList();}}在运行时,这会抛出一个System.InvalidOp