首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Linq to Sql 更新数据时容易忽略的问题

越来越多的朋友喜欢用Linq to Sql来进行开发项目了,一般我们都会遇到CRUD等操作,不可否认,在查询方面Linq真的带来很大的便利,性能方面也表现不错,在插入操作和删除操作中,Linq的表现也还不错...,但是在更新某条记录的时候,性能就相对比较弱了,我们一般会使用ExecuteSql等方法来执行脚本。...不过有时候,我们还是会使用Linq to Sql来进行Update,执行的步骤:获取一个记录-〉更新字段 -〉submitChanges() 昨天遇到了一个问题,流程都没有错,但是更新的时候始终没有更新到数据库...context.SubmitChanges(); } 简单的代码,大概的意思也是获取一个记录,然后更新字段,再submitChanges,大体看看没有错,但是!!!!...context.SubmitChanges(); } 标签: C#,linq to sql,仔细,项目 好了,文章比较简单,也或许你觉得不值得一提,目的也不是为了解决这个问题,希望大家能在做项目中,一定要仔细

1.3K80
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Linq to sql并发与事务

    之前SQL语句库存-2生效了,而我们程序的更新(库存-1)被放弃了。在页面上也显示了所有分类为1的产品ID(因为我们之前的SQL语句是对所有分类为1的产品都进行修改的)。       ...产品价格没有变化,库存-1了,都是我们程序的功劳,SQL语句的更新被放弃了。       ...来测试一下,在执行了SQL后再继续程序可以发现界面上只输出了数字1,说明在第一条记录失败后,后续的并发冲突就不再处理了。...事务处理        Linq to sql在提交更新的时候默认会创建事务,一部分修改发生错误的话其它修改也不会生效: ctx.Customers.Add(new Customer { CustomerID...执行程序后会得到一个异常,查询数据库发现“abcdf”这个顾客也没有插入到数据库中。

    67920

    LINQ to SQL(1):基础入门

    LINQ to SQL是在SQL SERVER数据库上设置一个强类型化界面的方式,LINQ to SQL提供的方式是目前我所见到查询SQL SERVER最简单也是最有效的方式,他可以使用自定义的类型与数据表甚至存储过程进行对应...,而不像我们使用ADO.NET那样,把更多的功夫用在数据类型转换等等的问题上,当程序运行的时候,LINQ to SQL会将我们使用自己的语言定义的模型中的语言继承查询转换为SQL,然后将他在数据库上执行...LINQ语句 注意:本节以及以后的数据库示例,我想会放到文章最后,有兴趣的朋友可以直接下载,如果您有sql 2000/2005的示例数据库,就不需要啦 找到northwind(下载),附加到您的数据库就可以啦..._City = value; } } } 好了,我们已经创建了一个类与一个Customers表进行映射,接来下就是LINQ to SQL中最最最重要的一个类出场啦DataContext...to SQL模型,怎么样,LINQ to SQL的查询方式,是不是很让人心潮澎湃啊

    1.4K60

    LINQ to SQL(4):OR设计器

    在我们使用LINQ to SQL的时候,需要大量的使用OR设计器,虽然我们手工写代码也是完全可以实现的,但是OR设计器是非常强大的工具,我想有了它,没有几个人会去手工写代码,当然了,手动写代码也是必须的...这一篇我就写几个典型的需要手工写代码的情况 打开和关闭复数形式 默认情况下,OR设计器会将数据库对象从服务器资源管理器拖放到OR设计器上的时候,会自动将ies,s结尾修改为单数形式,这样可以更准确的表示实例化的实体类到单个数据记录的事实...像第一节写的那样),他包含“用户名”,“姓名”,“年龄”等属性,当然了,我们完全也可以在外部声明一个这样的类型,但是这样不光破坏了对象的封装,而且在使用上也增加了复杂度 向实体类中添加验证 验证实体类是指确认输入到数据对象中的值是否符合对象架构内的约束...在将更新发送到基础数据库之前对数据进行验证是一种很好的做法,这样可以减少错误。...还可以减少应用程序和数据库之间的潜在往返行程次数 在对实体类中添加验证的时候,有两个不同的阶段,分别是在列值更改过程中验证数据和在事体类更新过程中验证数据,由于 C# 项目不会自动生成事件处理程序,因此您可以使用

    927100

    非常帅气的Linq to sql

    在数据库数据层自动化上,Linq强大地让我很惊喜。...(方法见:http://msdn.microsoft.com/zh-cn/library/ms247254.aspx)然后需要做的就是新建Linq to Sql项,然后把建好的表拖进来,一切都是可视化,...code:MyBlog.cs -sprocs 然后他帮我生成了个74Kb的文件,文件名是MyBlog.cs,生成的时候要注意的就是因为我用的是0.2.0.1版本,需要把MySql.Data.dll复制到DbMetal...第一次尝试Linq to Sql的时候我就有个疑问,他的效率怎么样?...Server是Express版的没有分析工具),我很惊喜地发现Linq最为神奇的地方在于在写完select的那一句的时候并没有连接数据库,Linq会在需要访问数据的时候从已知条件生成SQL语句从提交给数据库

    81510

    SQL To LinQ 你知道么?

    学习linQ的时候,你应该用到过LinQ to SQL 的工具---LinQPad,刚开始用,不太熟悉,尤其是涉及到多表查询,不会写LinQ语句怎么办?    ...这不是问题,下面先来介绍另一个工具 SQL to LinQ,SQL已经学了很长时间了,做系统的时候经常用到,对于SQL语句应该不陌生吧。    ...然后,打开SQL to LinQ,Tools--Linqer Connections,新建连接: ?   选择Add: ? 设置要连接的数据库, ? 选择LinQ to Entities: ?...确认,将SQL语句复制到左边的SQL框中,在上边的Connection中选择你刚新建的连接,执行,然后右边就会把相应的LinQ语句显示出来: ?  ...把LinQ语句,复制到LinqPad中,运行: ?  Perfect!!!,善用工具,提高开发效率!

    58120

    LINQ to SQL 使用指南

    LINQ to SQL 是 Microsoft 提供的一种用于 .NET Framework 的对象关系映射器(ORM),它允许开发人员使用 LINQ 查询语法来操作数据库中的数据,而无需直接编写 SQL...本文将从基础概念入手,逐步深入介绍 LINQ to SQL 的使用方法,并探讨一些常见的问题及其解决策略。什么是 LINQ to SQL?...基本步骤创建数据模型:使用 LINQ to SQL 工具自动生成或手动创建与数据库表对应的 C# 类。执行查询:使用 LINQ 查询语法来检索、更新、插入或删除数据。...创建 LINQ to SQL 数据模型首先,我们需要创建一个 LINQ to SQL 的数据上下文以及相关的数据模型类。...正确地使用 LINQ to SQL 可以极大地简化数据访问逻辑,并提高应用程序的开发效率。希望这篇指南能够帮助你在项目中更有效地应用 LINQ to SQL。

    30820

    LINQ能不能用系列(二)LINQ to SQL 效率比对

    前言 很多人听说过LINQ TO SQL与ADO.NET传统方式用于不同的环境,LINQ TO SQL与ADO.NET传统方式也没有可比性,就像公交车与私家车一样,虽然是车但用途完全不同,但很少有人去探究...下面一起来看LINQ TO SQL效率到底如果吧。...内容 测试环境:net framework 4.0 + Sql Server 2008 测试用途:100w条数据 like 查询,原因添加、修改、删除消耗资源与时间相对较少,不易测试,查询里面最消耗时间的无非就是...; using System.Data.SqlClient; namespace LINQProject { /// /// 游戏信息业务处理类(LINQ TO SQL...LINQ TO SQL第一次的时候比较消耗资源,原因LINQ第一次初始化比较耗时,之后LINQ查询与ADO.NET几乎一样,在100w条数据下随然数据大同小异,但已经足够说明问题,LINQ TO SQL

    1.2K50

    LINQ to SQL(3):增删改查

    上一节中,我已经写过了利用OR设计器生成对象模型的方式,其实生成这样对数据库进行映射的模型的方式不只这一种,不过VS为我们提供的这种设计器真的是很强大,在实际应用中也是经常用到的 这一节写利用LINQ...to SQL对数据库进行的简单增删改查的操作的实现方式,这里注意是“简单”,复杂的查询呢,我将会在下一篇或者下下一篇中写到,那里会有很多的内容,比如处理并发啦,自定义LINQ表达式查询啦,等等的这些,而下一篇中我计划写一些关于扩展...City = "London" }; dc.Customers.InsertOnSubmit(insertCustomer);//当提交更改时候插入insertCustomer到表...绝对的雷同,不是巧合,当然了,访问视图的规则,还是必须要和数据库中我们创建视图的规则一样的,能怎么操作,不能怎么操作,不是由LINQ to SQL决定的,OR设计器只是帮助我们生成了一个实体类对于视图结果集的一个映射而已...怎么样,简单到不可思议吧,必要怀疑,不要以为LINQ to SQL是多么高深的话题,完全没有,但是,中国话呀,就是这样,一说“但是”就要麻烦啦,没错,在我们享受它的方便快捷的同时,也会经常遇到这样那样的问题

    71590

    LINQ to SQL 辅助工具

    当你在项目中使用LINQ to SQL的时候, 有一个事情是必须要非常注意的, 那就是要关心一下LINQ to SQL帮你生成的SQL语句, 尤其在你还不是非常熟悉LINQ to SQL的语法, API...一、DataContext本身有提供Log属性来将LINQ to SQL生成的SQL语句格式化并输出到控制台窗口, 通常是这样: DataContextInstance.Log = Console.Out...二、可以看到所能生成的 SQL 语句了,Debug过程中想查看结果怎么办,大牛ScottGu为我们准备了个好东东,参看http://weblogs.asp.net/scottgu/archive/2007.../07/31/linq-to-sql-debug-visualizer.aspx 工具下载:http://www.scottgu.com/blogposts/linqquery/SqlServerQueryVisualizer.zip...将压缩包中的 SqlServerQueryVisualizer.dll 拷贝到 \Program Files\Microsoft Visual Studio 9.0\Common7\Packages\Debugger

    87490

    linq to sql中慎用Where(Func predicate),小心被Linq给骗了!

    近日在一个大型Web项目中,采用Linq to Sql替换原来的sqlcommand/sqldatareader方式来获取数据,上线后刚开始一切正常,但是随着访问量的增加,网站明显慢了很多,监测服务器CPU...而这些SQL都是Linq自动翻译并最终提交到数据库的,查看了相关的代码,明明写着Skip(n).Take(m)类似的语句,为何还会生成这么“傻”的sql呢?...} 修改的用意在换一种方法(即Where(Expression))取数据,运行后输出结果跟上一种方式完全相同,而且这种方式可以在调用方法前动态创建需要的查询条件表达式,用法更灵活,但是我跟踪到的...sql语句却是: SELECT [t0]....恳请园子里的哪位linq达人,能解释一二?

    1K50

    LINQ to SQL(2):生成对象模型

    在LINQ to SQL中,可以使用自己的编程语言的对象模型映射到关系数据库,在上一节课,已经有一部分内容,简单的介绍了一下这种对象模型的结构,这一节,我们主要讲使用vs给我们提供的工具来生成对象模型的方法...在“数据”的NODE上点击“LINQ to SQL类”,数据想用的名字,点击“添加” ?...直接跳到添加完数据库的连接以后,这里要注意需要把我们需要的表、视图、存储过程在创建连接是添加进来 在服务器资源管理器中,找到我们刚才创建的数据库连接,然后打开“表”选项卡,然后拖动Customers表到OR...SubmitChange的时候,模型就会知道有那些属性有更改过,然后把这个更改写回给数据库,这个我想我会在下一节中重点写到,所以这里就不多做解释啦,只需要知道他的功能就好了 然后,我们再把一个另一个Orders表拖拽到OR...to SQL返回一个强类型化的对象 怎么样,如果在上一节中LINQ to SQL的查询方式让你耳目一新、心潮澎湃的话,那么OR设计器的方便快捷,是不是让你有一种令狐冲在西湖水牢牢底摸到了任天行留下的吸星大法的感觉呢

    81340

    SQL标准简介

    Table of Contents ---- SQL 的起源 SQL 的标准化 SQL 标准的历史 学习 SQL 标准 SQL 标准的符合性 SQL 的起源 ---- 通常认为,SQL 是 Structured...就对 SQL 标准化进程提出了置疑。WISCorp 2 网站曾经收集了很多相关的文档,JCC3 网站则提供了比较新的更新。...如果要了解标准的内容,比较推荐的方法是泛读 SQL92(因为它涉及了 SQL 最基础和最核心的一些内容),然后增量式的阅读其他标准。标准在每次更新的时候,委员会的成员们都为大家提供比较好的介绍文档。...例如,针对 SQL:2011,SIGMOD Record 上就有很不错的介绍4。针对 SQL:2016,这是一个很好的更新5,这6也是一个很好的补充。...大到功能特性,小到语法语义的细节,在不同产品之间都存在很多差异,造成实际的应用迁移远比 C/C++ 程序的迁移要复杂很多。

    7.5K84
    领券