草庐IT

find-by-sql

全部标签

c# - 与 SQL Server 的初始连接速度很慢。为什么?

我遇到过在两个站点安装C#应用程序的情况,这两个站点与SQLServer的初始连接速度极慢。我编写了一个测试应用程序来验证减速发生的位置,它是在第一个SQLConnection.Open语句上。通过命名管道建立与服务器的连接大约需要41秒。我们认为这可能是DNS问题,但使用TCP/IP连接时速度同样慢。建立初始连接后,连接被合并,应用程序正常响应。工作站和服务器都是运行Windows7Pro、Core2Duo3.16Ghz和4GBRam的不错机器。我确实在微软论坛上找到了以下文章:http://social.msdn.microsoft.com/Forums/en/windowscom

c# - 什么.NET StringComparer 相当于 SQL 的 Latin1_General_CI_AS

我在我的数据库和我的C#代码之间实现了一个缓存层。这个想法是根据查询的参数缓存某些数据库查询的结果。数据库使用默认排序规则-SQL_Latin1_General_CP1_CI_AS或Latin1_General_CI_AS,我相信基于一些简短的谷歌搜索,这等同于相等,只是排序不同。我需要一个.NETStringComparer,它可以为我提供相同的行为,至少对于相等性测试和哈希码生成,就像数据库的排序规则正在使用的那样。目标是能够在C#代码中的.NET字典中使用StringComparer来确定特定字符串键是否已在缓存中。一个真正简化的例子:varcomparer=StringComp

c# - 如何从 SqlDataReader 读取 SQL Server COUNT

我正在尝试使用C#SqlDataReader查找表的计数,但我一直在获取invalidattempttoreadwhennodataispresent我的代码:stringsql="SELECTCOUNT(*)FROM[DB].[dbo].[myTable]";SqlCommandcmd=newSqlComman(sql,connectionString);SqlDataReadermySqlDataReader=cmd.ExecuteReader();intcount=mySqlDataReader.GetInt32(0);//HereiswhereIgettheerror.我知道我

c# - 如何清除 Linq to Sql 上的 DataContext 缓存

我正在使用LinqtoSql查询某些数据库,我只使用Linq从数据库中读取数据,并通过其他方式对其进行更改。(这是无法更改的,这是我们正在扩展的应用程序的限制,所有更新都必须通过其sdk)。这很好,但是我遇到了一些缓存问题,基本上,我使用Linq查询一行,然后通过外部方式删除它,然后如果我再次使用linqi查询该行,我会在外部创建一个新行得到了旧的(缓存的)数据。我无法关闭对象跟踪,因为这似乎会阻止数据上下文自动加载相关属性(外键)。有什么方法可以清除DataContex缓存吗?我在网上找到了一个方法,但它似乎不安全:http://blog.robustsoftware.co.uk/2

c# - C# 中的 0.0/0.0 不会抛出 "Attempted to divide by zero."?

我在我friend的电脑上看到了这段财务计算代码:doubleTotal=...doublePaid=...doubleWating_For_Details=...doubleDecuctibles=...doubleRejected=...好吧,我一看到这个,就告诉他double以base2表示,NOT不能表示财务计算。使用decimal代替。很好。但是我把它改成double的那一刻我遇到了:试图除以零。嗯?显然-使用double时,除以0.0它确实NOT抛出异常:但返回NAN。虽然我的代码(使用decimal)确实抛出异常(当Total为0时)所以我问:我检查了0.0==0,它返回

c# - 为什么 .NET group by 在 buckets 数量增长时(非常)慢

给定这段简单的代码和1000万个随机数数组:staticintMain(string[]args){intsize=10000000;intnum=10;//increasenumtoreducenumberofbucketsintnumOfBuckets=size/num;int[]ar=newint[size];Randomr=newRandom();//initializewithrandumnumbersfor(inti=0;ii/num);varl=group.Count();s.Stop();Console.WriteLine(s.ElapsedMilliseconds);

c# - 将 Graphql 转换为 SQL?

我们有现有的SQLServer数据库,我们正在使用C#。假设我们的移动客户端向服务器发送了一个graphql。我如何转换此SQL,以便我的客户获得他期望的数据? 最佳答案 GraphQL和SQL虽然听起来很相似,但解决的问题不同。SQL用于直接查询数据库。GraphQL用于查询任何类型的数据源,例如数据库(通过SQL或客户端库)、API和静态文件。GraphQL可以与REST或临时API端点进行比较。一种解决方案是自己创建GraphQL实现。GraphQL.org有很多关于如何实现和使用GraphQL服务器的重要信息。如果工作量太大

c# - 将 SQL Rank() 转换为 LINQ 或替代方法

我有下面的SQL语句,可以按预期/预期工作。但是我想将它翻译成LINQ语句(Lambda??),以便它适合我的DAL的其余部分。但是我看不出如何在LINQ中模拟Rank()。我将其张贴在这里的原因(可能有误)是想看看是否有人可以替代Rank()语句,以便我可以将其切换。或者,如果有一种方法可以在LINQ中表示Rank(),我们也将不胜感激。USECMOSELECTvp.[PersonID]AS[PersonId],ce.[EnrollmentID],vp.[FirstName],vp.[LastName],ce.[EnrollmentDate],ce.[DisenrollmentDat

c# - SQL 服务器 : invalid object name in query execution

我正在尝试执行Insert语句,但一直收到Invalidobjectname错误。这是我的代码:publicstringaddNewComment(intuserID,intpageID,stringtitle,stringcomment){stringquery="INSERTINTOdbo.nokernok_kommentarer(userID,pageID,commentTitle,comment)"+"VALUES("+userID+","+pageID+",'"+title+"','"+comment+"')";adapter.InsertCommand=newSqlComm

c# - IDENTITY INSERT 和 LINQ to SQL

我有一个SQLServer数据库。该数据库有一个名为Item的表。项目有一个名为“ID”的属性。ID是我表上的主键。这个主键是一个增量值为1的整数。当我尝试插入记录时,我收到一条错误消息:Cannotinsertexplicitvalueforidentitycolumnintable'Item'whenIDENTITY_INSERTissettoOFF.".我正在尝试使用以下代码插入记录:publicintAddItem(Itemi){try{intid=0;using(DatabaseContextcontext=newDatabaseContext()){i.CreatedOn=