前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Linq to Sql 更新数据时容易忽略的问题

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

作者头像
脑洞的蜂蜜
发布2018-02-01 18:07:18
1.3K0
发布2018-02-01 18:07:18
举报
文章被收录于专栏:NetCoreNetCore

越来越多的朋友喜欢用Linq to Sql来进行开发项目了,一般我们都会遇到CRUD等操作,不可否认,在查询方面Linq真的带来很大的便利,性能方面也表现不错,在插入操作和删除操作中,Linq的表现也还不错,但是在更新某条记录的时候,性能就相对比较弱了,我们一般会使用ExecuteSql等方法来执行脚本。

不过有时候,我们还是会使用Linq to Sql来进行Update,执行的步骤:获取一个记录-〉更新字段 -〉submitChanges()

昨天遇到了一个问题,流程都没有错,但是更新的时候始终没有更新到数据库,

大概得伪代码如下:

public void UpdateUser(User user) {             DataContext context = new DataContext("conn");             User existsUser = GetUser(user.ID);             existsUser.Name = user.Name;             //.............             context.SubmitChanges(); }

简单的代码,大概的意思也是获取一个记录,然后更新字段,再submitChanges,大体看看没有错,但是!!!!大家有没有发觉,我们的context是个私有变量,而我们的GetUser虽然也是从context中取得,不过它用的是它自己的context,也就是说对于程序来说,它是两个对象,所以我们这里在submitChanges的时候,无论你怎么改都是没有效果的,数据库中始终不会改变,My God ,或许你会觉得这谁不知道啊,但是往往我们真的会忽略这一点,记得以前考试,往往都是难的题目基本上全对,但越简单越容易的题目,却会经常犯错,希望这些能对你有些启发。

好了,知道了为什么出错,修改也简单了,两种方法:

方法一: public void UpdateUser(User user) {     DataContext context = new DataContext("conn");             //从当前context取     User existsUser = context.Users.SingleOrDefault(e => e.ID.Equals(user.ID);     existsUser.Name = user.Name;             //.............     context.SubmitChanges(); } 方法二: //把context设成上下文公用的 DataContext context = new DataContext("conn"); public void UpdateUser(User user) {     User existsUser = GetUser(user.ID);                existsUser.Name = user.Name;             //.............     context.SubmitChanges(); }

标签: C#linq to sql仔细项目

好了,文章比较简单,也或许你觉得不值得一提,目的也不是为了解决这个问题,希望大家能在做项目中,一定要仔细,因为往往你的一个小小的疏忽,会给项目、公司带来不可预知的后果。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2009-06-12 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档