iis服务器助手广告
返回顶部
首页 > 资讯 > 精选 >Linq更新数据实用吗
  • 351
分享到

Linq更新数据实用吗

2023-06-17 22:06:08 351人浏览 八月长安
摘要

本篇内容主要讲解“Linq更新数据实用吗”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Linq更新数据实用吗”吧!WEB 2.0的网站少不了数据库、数据访问,也是一切操作之本,而VS 2008中

本篇内容主要讲解“Linq更新数据实用吗”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Linq更新数据实用吗”吧!

WEB 2.0的网站少不了数据库、数据访问,也是一切操作之本,而VS 2008中***的亮点之一Linq也恰巧是做这个的,所以我的开发从Linq、从数据库开始。网上关于Linq的教学铺天盖地,我不准备重复,我只写下我遇到的问题。Linq更新数据怎么就那么费劲?

Linq的全称是Language Integrated Query ,也就是说Linq是以一个查询语言的方式出现在我们面前的。在查询方面Linq做了不少的优化,我们不用在费尽心思去拼装sql语句、组装实体等,所有操作在Linq里都是强类型的,我们用C#代码轻松地写出漂亮的SQL语句。

那么做为一个查询语言,Linq更新数据方面又是怎么表现的呢?通常来说Linq的更新会以以下的方式出现(绝大部分教程中都是这么写的)

var ctx = new MyDataContext();  var user = ctx.Users.Where(u => u.UserId == userId).Single();  user.UserName = "New User Name";  ctx.SubmitChanges();

这些是C#代码,但是背后做了什么呢?Linq会为我们生成类似一下的SQL语句

第一步,查询

SELECT UserId, UserName, FirstName, LastName, CreatTime From User WHERE UserId = @userId

第二部,更新

UPDATE User SET UserName = @newUserName  WHERE UserId = @oldUserId, userName = @oldUserName, FirstName = @oldFirstName, LastName = @oldLastName

发现了什么?首先Linq会取出所有的字段,在user.UserName = "New User Name"的时候,记录下UserName字段被更新过了,UPDATE时会只更新UserName,但是把之前所有字段的值放在WHERE语句里来做为条件。

Are you kidding?! 这样的效率实在是太差了吧?!

抛开效率问题,接下来我们看另外一种更新数据,有个某个字段记录页面被访问的次数,平时我们会用

UPDATE POST SET Views = Views + 1 WHERE PostId = @PostId

但是如果我们写下如下C#代码

var ctx = MyDataContext();  var post = ctx.Posts.Where(p => p.PostId = @postId).Single();  post.Views++  ctx.SubmitChanges();

Linq更新数据会怎么做呢?和上面一样!取出所有字段,把View加一,用所有字段做为条件(包括Views),更新回去。

设想一下,这样一个被频繁使用的计数器,两次操作出现SELECT与UPDATE交叉情况的可能性很大,那么后者还能更新成功么?

微软就是这样解释的,如果在你Linq更新数据中,有其他人更新了这一行,那么这一行也就不是你所需要的那一行了,为了防止这样的冲突,所以把所有字段都放在WHERE语句中,这是by design的。

你可以通过其他方法进行更新数据,然而在目前版本,这个方法也表现的不怎么样。

System.Data.Linq.Table有一个Attach方法,带有三个重载,用来直接更新数据的,我们来一个一个的来看看。

Attach(T entity)  var ctx = new MyDataContext();  var newUser = new User();  newUser.UserId = new Guid("xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx");//假设作为参数传进来的  newUser.UserName = "New User Name";  ctx.Users.Attach(newUser);  ctx.SubmitChanges();   //结束

运行完全没有任何效果,SQL Profiler无任何记录。

Attach(T entity, T original)  var ctx = new MyDataContext();  var newUser = new User();  newUser.UserId = new Guid("xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx");//假设作为参数传进来的  newUser.UserName = "New User Name";  var user = ctx.User.Where(u => u.UserId = newUser.UserId).Single();  ctx.Users.Attach(newUser, user);  ctx.SubmitChanges();    //结束

运行时提示: Cannot add an entity with a key that is already in use.

Attch(T entity, bool asmodified)  var ctx = new MyDataContext();  var newUser = new User();  newUser.UserId = new Guid("xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx");//假设作为参数传进来的  newUser.UserName = "New User Name";  ctx.Users.Attach(newUser, true);  ctx.SubmitChanges();    //结束

运行时提示:An entity can only be attached as modified without original state if it declares a version member or does not have an update check policy.

怎么办?提示中说"declares a version member ",通常来说是指SQL Server中TimeStamp类型的字段,在你所需要更新的表中加上一个字段,并标记为TimeStamp就可以了。但是这样做,对于我们来说仍然是个浪费,并且WHERE语句中仍然会出现TimeStamp的限制。

你还可以通过在字段上设置UpdateCheck.Never属性来避免更新检查,但是如果数据表更新、新增存储过程,需要重新生成dbml的话,你需要手动重新设置一遍。

Linq更新数据甚至没有一个类似Web引用中Update Web Reference的操作来让你方便的在数据表更新后更新dbml,并且在这个版本都不会提供,你所能做的只有删除原来的表,刷新Server Exploer,重新拖拽到dbml的设计视图中,或者,写个脚本,让SQLMETAL来帮你完成这些。

到此,相信大家对“Linq更新数据实用吗”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

--结束END--

本文标题: Linq更新数据实用吗

本文链接: https://www.lsjlt.com/news/293544.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Linq更新数据实用吗
    本篇内容主要讲解“Linq更新数据实用吗”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Linq更新数据实用吗”吧!WEB 2.0的网站少不了数据库、数据访问,也是一切操作之本,而VS 2008中...
    99+
    2023-06-17
  • LINQ to SQL数据库如何更改
    这篇文章主要介绍“LINQ to SQL数据库如何更改”,在日常操作中,相信很多人在LINQ to SQL数据库如何更改问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”LINQ to SQL数据库如何更改”的疑...
    99+
    2023-06-17
  • vue+echarts实现数据实时更新
    本文实例为大家分享了vue+echarts实现数据实时更新的具体代码,供大家参考,具体内容如下 今天在管理后台新增一个图表,用了echarts,记录一下 根据数据实时更新 安装 np...
    99+
    2024-04-02
  • 使用@CachePut 更新数据库和更新缓存
    目录关于更新缓存 ,要注意两点1、@Cacheable的key2、@CachePut的返回值缓存的CachePut冲突Cacheable可以分解成两个关于更新缓存 ,要注意两点 1、...
    99+
    2024-04-02
  • mybatis 实现插入或更新数据功能,数据存在时只更新
    需求 提供一个接口,既能保证新数据的插入操作,又能在数据存在时进行数据更新操作 实现:on duplicate key update 在mysql中,提供有on duplicate key updat...
    99+
    2023-09-08
    mybatis 数据库 mysql
  • numpy如何实时更新数据?
    NumPy是Python中用于科学计算的一个重要的库。它提供了许多用于处理大型数组和矩阵的函数和方法。在数据分析和机器学习领域中,NumPy是一个必须掌握的工具。在本文中,我们将学习如何在NumPy中实时更新数据。 NumPy中提供了一些函...
    99+
    2023-10-11
    path numpy 实时
  • [Mysql] 更新数据
    使用UPDATE语句可以对数据表中的现有数据进行更新 语法结构 UPDATE 表名SET 列1=值1,列2=值2...[WHERE 条件][ORDER BY...][LIMIT row_count]; SET命令用来...
    99+
    2023-09-02
    mysql sql
  • Windows update更新有用吗?有必要进行更新吗?
    不少电脑爱好者在讨论Windows update更新有用吗?对于这个问题,其实在网上很多论坛也有激烈讨论。其实我们讨论Windows update更新主要是针对其对我们电脑系统的影响以及用户体验方面。那么Windows ...
    99+
    2023-05-31
    Windows update 更新
  • 使用javascript怎么实现页面无刷新更新数据
    这篇文章给大家介绍使用javascript怎么实现页面无刷新更新数据,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。 首先在服务器上建立一个CheckUser.asp文件,用来检测用户是否存在,根据用户是否存在...
    99+
    2023-06-10
  • 如何使用@CachePut更新数据库和更新缓存
    小编给大家分享一下如何使用@CachePut更新数据库和更新缓存,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!关于更新缓存 ,要注意两点1、@Cacheable的...
    99+
    2023-06-22
  • 使用saveOrUpdateBatch实现批量插入更新数据
    saveOrUpdateBatch 是 Hibernate 中的一个方法,可以用来批量插入或更新数据。这个方法的参数是一个 List,里面可以存储多个实体对象。当 Hibernate 执行这个方法时,会检查每个实体对象是否存在主键,如果存在...
    99+
    2023-08-31
    hibernate spring java 后端
  • jquery php怎么实现实时数据更新
    本篇文章给大家分享的是有关jquery php怎么实现实时数据更新,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。本文操作环境:Windows7系统、PHP7.1版、Dell G...
    99+
    2023-06-22
  • oracle怎么更新数据返回最新数据
    要更新数据并返回最新数据,可以使用以下步骤: 首先,使用UPDATE语句更新数据库中的数据。例如,更新一个名为"...
    99+
    2024-04-09
    oracle
  • hbase实时数据更新怎么配置
    要实现HBase的实时数据更新,可以通过以下方式进行配置: 使用HBase的WAL(Write Ahead Log)机制:将HB...
    99+
    2024-04-02
  • MySQL如何实现数据批量更新
    最近需要批量更新大量数据,习惯了写sql,所以还是用sql来实现,下面这篇文章主要给大家总结介绍了关于MySQL批量更新的方式,需要的朋友可以参考下 根据不同条件批量更新同一值 这种场景直接通过update语句更新即可,如: 1 UP...
    99+
    2023-10-20
    mysql 数据库
  • mysql联表更新数据怎么实现
    要实现MySQL联表更新数据,可以使用UPDATE语句结合JOIN语句来完成。具体步骤如下: 根据需要的条件,使用SELE...
    99+
    2024-04-09
    mysql
  • mongodb批量更新数据怎么实现
    在 MongoDB 中,可以使用 updateMany() 方法来批量更新数据。下面是一个示例: 假设有一个名为 users 的集合...
    99+
    2024-04-09
    mongodb
  • elementui中使用el-tabs切换实时更新数据
    目录使用el-tabs切换实时更新数据el-tabs切换确认实现效果相关知识解决代码解释使用el-tabs切换实时更新数据 项目中使用el-tabs 发现会一次性把所有 tab 里的...
    99+
    2022-11-13
    elementui el-tabs el-tabs切换 实时更新数据
  • Linq如何使用数据表
    这篇文章主要为大家展示了“Linq如何使用数据表”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Linq如何使用数据表”这篇文章吧。首先让大家了解下Linq使用数据表,然后全面介绍生成的SQL语句...
    99+
    2023-06-17
  • mongodb如何更新数据
    mongodb中更新数据的方法:在mongodb中可以使用update()和save()方法来更新集合中的文档数据,update()语法例如“db.col.update( { "count" : { $gt : 1 } ...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作