我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Linq DataContext有什么用

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Linq DataContext有什么用

这篇文章主要介绍了Linq DataContext有什么用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

主键缓存

Linq to sql对查询过的对象进行缓存,之后的如果只根据主键查询一条记录的话会直接从缓存中读取。比如下面的代码:

Customer c1 = ctx.Customers.Single(customer => customer.CustomerID == "ANATR");  c1.ContactName = "zhuye";  Customer c2 = ctx.Customers.Single(customer => customer.CustomerID == "ANATR");   Response.Write(c2.ContactName);

执行后只会产生一条SQL:

  1. SELECT [t0].[CustomerID], [t0].[CompanyName], [t0].[ContactName], [t0].
    [ContactTitle], [t0].[Address], [t0].[City], [t0].[Region], [t0].
    [PostalCode], [t0].[Country], [t0].[Phone], [t0].[Fax]  

  2.  

  3. FROM [dbo].[Customers] AS [t0]  

  4.  

  5. WHERE [t0].[CustomerID] = @p0  

  6. -- @p0: Input String (Size = 5; Prec = 0; Scale = 0) [ANATR] 

由于没有提交修改,所以数据库中的记录还是没有更新。由于这个特性,我们在使用存储过程作为实体更新方法的时候就要当心了,存储过程书写错误,即使你提交了修改也很可能导致缓存中的数据和数据库中的数据不一致,引起不必要的麻烦。

Linq DataContext隔离

有的时候我们会把对象从外部传入Linq DataContext,要求它更新,由于不同的Linq DataContext是相对独立的。由于新的Linq DataContext中还没有获取实体,我们只能通过附加方式更新数据。

首先把Customer表的主键字段加上IsVersion标识:

  1. [Column(Storage="_CustomerID", DbType="NChar(5) NOT NULL", 
    CanBeNull=false, IsPrimaryKey=true, IsVersion = true)] 

运行下面的测试代码:

  1. Customer c = new Customer { CustomerID = "ALFKI", 
    ContactName = "zhuye", CompanyName = "1111" };  

  2.  

  3. ctx.Customers.Attach(c, true);  

  4. ctx.SubmitChanges(); 

会捕捉到下面的SQL语句:

  1. UPDATE [dbo].[Customers]  

  2. SET [CompanyName] = @p2, [ContactName] = @p3, [ContactTitle] = @p4, 
    [Address] = @p5, [City] = @p6, [Region] = @p7, [PostalCode] = @p8, 
    [Country] = @p9, [Phone] = @p10, [Fax] = @p11  

  3. WHERE ([CustomerID] = @p0) AND ([CustomerID] = @p1)  

  4. -- @p0: Input StringFixedLength (Size = 5; Prec = 0; Scale = 0) [ALFKI]  

  5. -- @p1: Input String (Size = 5; Prec = 0; Scale = 0) [ALFKI]  

  6. -- @p2: Input String (Size = 4; Prec = 0; Scale = 0) [1111]  

  7. -- @p3: Input String (Size = 5; Prec = 0; Scale = 0) [zhuye]  

  8. -- @p4: Input String (Size = 0; Prec = 0; Scale = 0) []  

  9. -- @p5: Input String (Size = 0; Prec = 0; Scale = 0) []  

  10. -- @p6: Input String (Size = 0; Prec = 0; Scale = 0) []  

  11. -- @p7: Input String (Size = 0; Prec = 0; Scale = 0) []  

  12. -- @p8: Input String (Size = 0; Prec = 0; Scale = 0) []  

  13. -- @p9: Input String (Size = 0; Prec = 0; Scale = 0) []  

  14. -- @p10: Input String (Size = 0; Prec = 0; Scale = 0) []  

  15. -- @p11: Input String (Size = 0; Prec = 0; Scale = 0) [] 

感谢你能够认真阅读完这篇文章,希望小编分享的“Linq DataContext有什么用”这篇文章对大家有帮助,同时也希望大家多多支持编程网,关注编程网行业资讯频道,更多相关知识等着你来学习!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Linq DataContext有什么用

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

下载Word文档

猜你喜欢

Linq DataContext有什么用

这篇文章主要介绍了Linq DataContext有什么用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。主键缓存Linq to sql对查询过的对象进行缓存,之后的如果只根据
2023-06-17

Linq to SQL的DataContext怎么写

本篇内容介绍了“Linq to SQL的DataContext怎么写”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!强类型DataContex
2023-06-17

LINQ DataContext类问题怎么解决

本篇内容介绍了“LINQ DataContext类问题怎么解决”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!LINQ DataContext
2023-06-17

Linq有什么作用

本篇内容主要讲解“Linq有什么作用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Linq有什么作用”吧!学习Linq在我们的软件中,数据的重要性不可言喻,特别是象ERP,CRM等等这类商业应用
2023-06-17

LINQ to SQL有什么用

这篇文章将为大家详细讲解有关LINQ to SQL有什么用,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。LINQ to SQL 目前只支持SQL Server(SQL Server Compact版本正在
2023-06-17

LINQ有什么优点

这篇文章主要讲解了“LINQ有什么优点”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“LINQ有什么优点”吧!1、易用性。每当新的技术推送到业界,有不少追随者就会跟着使用。方便、易用就成为了关
2023-06-17

LINQ匿名类型有什么用

这篇文章给大家分享的是有关LINQ匿名类型有什么用的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。LINQ匿名类型(Anonymous Types)LINQ能够利用的另一个C#和VB新特性之一就是对“LINQ匿名类
2023-06-17

Linq Tracking Changes机制有什么作用

这篇文章主要介绍“Linq Tracking Changes机制有什么作用”,在日常操作中,相信很多人在Linq Tracking Changes机制有什么作用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”L
2023-06-17

LINQ是什么

本篇内容介绍了“LINQ是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!LINQ是什么LINQ是Language Integrated
2023-06-17

LINQ to SQL与NHibernate有什么不同

这篇文章主要讲解了“LINQ to SQL与NHibernate有什么不同”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“LINQ to SQL与NHibernate有什么不同”吧!1 引言
2023-06-17

LINQ是什么及怎么使用

本文小编为大家详细介绍“LINQ是什么及怎么使用”,内容详细,步骤清晰,细节处理妥当,希望这篇“LINQ是什么及怎么使用”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。一、为什么要使用LINQ要理解为什么使用LIN
2023-06-29

C#中LINQ的用途是什么

LINQ(Language Integrated Query)是C#中的一种功能,它允许开发人员使用类似SQL的查询语法来查询各种数据源,如集合、数据库、XML等。LINQ可以大大简化数据查询和操作的过程,提高代码的可读性和可维护性。其主要
C#中LINQ的用途是什么
2024-04-03

Linq 中orderby的作用是什么

本篇文章给大家分享的是有关Linq 中orderby的作用是什么,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。1.其实Linq orderby 与SQL 里的order by
2023-06-17

Linq to sql是什么

这篇文章主要讲解了“Linq to sql是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Linq to sql是什么”吧!什么是Linq to sqlLinq to sql(或者叫DL
2023-06-17

LINQ Expression tree是什么

这篇文章主要介绍LINQ Expression tree是什么,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!LINQ Expression tree一棵LINQ Expession tree在创建后就不可再改变。假如
2023-06-17

LINQ to XML是什么

本篇内容介绍了“LINQ to XML是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!在向大家详细介绍LINQ to XML之前,首先让
2023-06-17

Linq本质是什么

这篇文章主要介绍“Linq本质是什么”,在日常操作中,相信很多人在Linq本质是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Linq本质是什么”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!1.匿名类
2023-06-17

DOM模型和LINQ模型有什么区别

这篇文章主要介绍“DOM模型和LINQ模型有什么区别”,在日常操作中,相信很多人在DOM模型和LINQ模型有什么区别问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”DOM模型和LINQ模型有什么区别”的疑惑有所
2023-06-17

LINQ表达式是什么

这篇文章主要讲解了“LINQ表达式是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“LINQ表达式是什么”吧!LINQ表达式简介1.OO(面向对象)以外的疆域:信息的访问与整合。关系数据库
2023-06-17

LINQ to SQL能做什么

本篇内容主要讲解“LINQ to SQL能做什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“LINQ to SQL能做什么”吧!一. LINQ to Objects只要实现了IEnumerab
2023-06-17

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录