VS2008的Linq,更新数据就那么费劲?
日期:2007年8月19日 作者: 查看:[大字体 中字体 小字体]-
用.Net两年了,也积累了一些知识和经验,觉得应该做出点自己的东西,而并不只是给别人打工。
所以决定利用最新发布的VS2008(Orcas) Beta2也加入到WEB 2.0的大潮中来,一来是学以所用,二来在实践中掌握最新的技术。
现在流行在开发阶段给项目起个Code Name,我也来凑凑热闹,就叫Pluto,以纪念不久前被剥夺九大行星资格的我们天蝎座的守护星——冥王星
平时有自己的工作,只能利用不多的业余时间开发,所以预计(争取)在VS2008正式发布之际,Pluto也能开发完成。
在这里,我会记录下开发Pluto中的一些事情。
WEB 2.0的网站少不了数据库、数据访问,也是一切操作之本,而VS 2008中最大的亮点之一Linq也恰巧是做这个的,所以我的开发从Linq、从数据库开始。网上关于Linq的教学铺天盖地,我不准备重复,我只写下我遇到的问题。
Linq,更新数据怎么就那么费劲?
Linq的全称是Language Integrated Query ,也就是说Linq是以一个查询语言的方式出现在我们面前的。在查询方面Linq做了不少的优化,我们不用在费尽心思去拼装SQL语句、组装实体等,所有操作在Linq里都是强类型的,我们用C#代码轻松地写出漂亮的SQL语句。
那么做为一个查询语言,Linq在数据更新方面又是怎么表现的呢?通常来说Linq的更新会以以下的方式出现(绝大部分教程中都是这么写的)
1var ctx = new MyDataContext();
2var user = ctx.Users.Where(u => u.UserId == userId).Single();
3user.UserName = "New User Name";
4ctx.SubmitChanges();
这些是C#代码,但是背后做了什么呢?Linq会为我们生成类似一下的SQL语句
1--第一步,查询
2SELECT UserId, UserName, FirstName, LastName, CreatTime From User WHERE UserId = @userId
3
4--第二部,更新
5UPDATE User SET UserName = @newUserName
6WHERE UserId = @oldUserId, userName = @oldUserName, FirstName = @oldFirstName, LastName = @oldLastName
发现了什么?首先Linq会取出所有的字段,在user.UserName = "New User Name"的时候,记录下UserName字段被更新过了,UPDATE时会只更新UserName,但是把之前所有字段的值放在WHERE语句里来做为条件。
Are you kidding?! 这样的效率实在是太差了吧?!
抛开效率问题,接下来我们看另外一种更新,有个某个字段记录页面被访问的次数,平时我们会用
1UPDATE POST SET Views = Views + 1 WHERE PostId = @PostId
但是如果我们写下如下C#代码
1var ctx = MyDataContext();
2var post = ctx.Posts.Where(p => p.PostId = @postId).Single();
3post.Views++
4ctx.SubmitChanges();
Linq会怎么做呢?和上面一样!取出所有字段,把View加一,用所有字段做为条件(包括Views),更新回去。
设想一下,这样一个被频繁使用的计数器,两次操作出现SELECT与UPDATE交叉情况的可能性很大,那么后者还能更新成功么?
微软就是这样解释的,如果在你更新过程中,有其他人更新了这一行,那么这一行也就不是你所需要的那一行了,为了防止这样的冲突,所以把所有字段都放在WHERE语句中,这是by design的。
你可以通过其他方法进行更新数据,然而在目前版本,这个方法也表现的不怎么样。
System.Data.Linq.Table<T>有一个Attach方法,带有三个重载,用来直接更新数据的,我们来一个一个的来看看。
Attach(T entity)
1var ctx = new MyDataContext();
2var newUser = new User();
3newUser.UserId = new Guid("xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx");//假设作为参数传进来的
4newUser.UserName = "New User Name";
5ctx.Users.Attach(newUser);
6ctx.SubmitChanges();
运行完全没有任何效果,SQL Profiler无任何记录。
Attach(T entity, T original)
1var ctx = new MyDataContext();
2var newUser = new User();
3newUser.UserId = new Guid("xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx");//假设作为参数传进来的
4newUser.UserName = "New User Name";
5var user = ctx.User.Where(u => u.UserId = newUser.UserId).Single();
6ctx.Users.Attach(newUser, user);
7ctx.SubmitChanges();
运行时提示: Cannot add an entity with a key that is already in use.
Attch(T entity, bool asmodified)
1var ctx = new MyDataContext();
2var newUser = new User();
3newUser.UserId = new Guid("xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx");//假设作为参数传进来的
4newUser.UserName = "New User Name";
5ctx.Users.Attach(newUser, true);
6ctx.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虽然做为一个查询语言出现,但是在数据更新方面也是做了不少工作的,尤其是一些CHECK的工作,但对于写惯SQL的我们来说,还是很不习惯,甚至觉得,这些工作你不替我做才好呢。
在没有更好解决办法的前提下,在更新操作上,老老实实的写SQL语句或者存储过程应该是个不坏的选择。(出处:急速软件下载学院)
-
- VS2008的Linq,更新数据就那么费劲? 相关文章:
- ·Word 2007里就能算算式 内置工具使用更方便
- ·别再糊涂 把共享就放在你眼皮底下
- ·PS抠图详细 明天你就是抠图高手
- ·仅用U盘就可以去除XP管理员密码
- ·巧设网卡 让Win Vista醒来就上网
- ·欢建游乐场_等待就是希望
- ·美女站长Kelly—我的站,就是我的家
- ·为什么我的QQ一登陆就出现版本太低?
- ·菜鸟必读:你的QQ号码、Q币就这样被盗
- ·原来刻录就是这么简单的事情
- VS2008的Linq,更新数据就那么费劲? 相关软件
- ·《毛利元就三箭之誓》试玩
- ·够胆就追我
- ·爱,就这么简单
- ·《闭上眼睛就是天黑》
- ·美食讲堂:《一学就会做炒饭》
- ·不爱就说你强奸
- ·你就是品牌
- ·生命就是做自己
- ·陪都就事
- ·我就是这么俗!作者-冰人
- 特别声明:本站除部分特别声明禁止转载的专稿外的其他文章可以自由转载,但请务必注明出处和原始作
- 者.文章版权归文章原始作者所有.对于被本站转载文章的个人和网站,我们表示深深的谢意。如果本站转
- 载的文章有版权问题请联系编辑人员,我们尽快予以更正. 转载请注明来源:http://www.hackhome.com
上一篇:谷歌将与天涯合作推出社区问答服务
精品推荐
热点TOP10
- ·2006年度好莱坞大片北美票房排行榜!
- ·一影楼用女学生裸体写真作宣传(图)
- ·68款破解小软件
- ·美国慈善组织邀中年妇女拍人体月历照
- ·诺基亚跨年演唱会现场照片
- ·色情视频网站“女主持”网上脱衣表演被逮捕
- ·苏州出现性虐用品商店(图)
- ·田海蓉全裸写真被指一脱成名(图)
- ·什么叫0day和Warez?
- ·解读身份认证技术现实化
- ·掌上电脑发展编年史(英文版)
- ·我的键盘和你的不一样(插图版)
- ·超女香港遭冷遇唐笑自摸舞姿大胆[图]
- ·吉林换妻俱乐部 须进行视频验证(图)
- ·《仙剑奇侠传3》新图不断 精彩不绝[图]
- ·日本新年歌会突现“裸体表演”(组图)
- ·智慧风尚 摩托A1200网络增强版将问世
- ·一名4岁小姑娘圣诞节遭奸杀(图)
- ·解决与IE冲突:金山词霸2003 SP3出炉
- ·《传奇3》遭大规模持续攻击 公安机关已立案
特别推荐
- ·2006年度好莱坞大片北美票房排行榜!
- ·夏季献礼《中国电子地图2007》正式面世
- ·苹果最新Leopard操作系统十大特性详解
- ·地图探险:我要地图网奥运寻宝活动开启
- ·网友千万当心:最卑鄙无耻的QQ骗术奇观
- ·我要地图积极创新 四大频道改版完成
- ·五一黄金周出游省钱有招 出游理财攻略
- ·微软200万美金收购清风网络!微软发力网站推广
- ·网站侵权4种情况免责 8种情形可不经许可不付酬
- ·出游好伙伴 我要地图桌面版评测
- ·API接口技术应用大赛闪亮登场
- ·网上100大系列骗子暴光
- ·我要地图Step By Step
- ·女人必看的十部电影
- ·什么叫0day和Warez?
- ·网友最想看的2007年春节晚会节目单出炉
- ·2006媒体十大流行语出炉
- ·液晶电视背光调节主动式将淘汰被动式
- ·长途每分钟0.18元超低话费背后的黑幕
- ·从细节设计谈笔记本普遍存在5大缺陷!
