Linq DataContext浅谈
创始人
2024-06-06 15:20:24
0

本文向大家介绍Linq DataContext,可能好多人还不了解Linq DataContext,没有关系,看完本文你肯定有不少收获,希望本文能教会你更多东西。

主键缓存

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

  1. Customer c1 = ctx.Customers.Single(customer => customer.CustomerID == "ANATR");  
  2. c1.ContactName = "zhuye";  
  3. Customer c2 = ctx.Customers.Single(customer => customer.CustomerID == "ANATR");  
  4.  
  5. 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 = 5Prec = 0Scale = 0) [ANATR] 

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

Linq DataContext隔离

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

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

  1. [Column(Storage="_CustomerID"DbType="NChar(5) NOT NULL"
    CanBeNull=falseIsPrimaryKey=trueIsVersion = 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 = 5Prec = 0Scale = 0) [ALFKI]  
  5. -- @p1: Input String (Size = 5Prec = 0Scale = 0) [ALFKI]  
  6. -- @p2: Input String (Size = 4Prec = 0Scale = 0) [1111]  
  7. -- @p3: Input String (Size = 5Prec = 0Scale = 0) [zhuye]  
  8. -- @p4: Input String (Size = 0Prec = 0Scale = 0) []  
  9. -- @p5: Input String (Size = 0Prec = 0Scale = 0) []  
  10. -- @p6: Input String (Size = 0Prec = 0Scale = 0) []  
  11. -- @p7: Input String (Size = 0Prec = 0Scale = 0) []  
  12. -- @p8: Input String (Size = 0Prec = 0Scale = 0) []  
  13. -- @p9: Input String (Size = 0Prec = 0Scale = 0) []  
  14. -- @p10: Input String (Size = 0Prec = 0Scale = 0) []  
  15. -- @p11: Input String (Size = 0Prec = 0Scale = 0) [] 

【编辑推荐】

  1. Linq结果集形状概述
  2. Linq存储过程返回详解
  3. Linq调用LoadProducts方法
  4. Linq使用数据表简单描述
  5. Linq对象引用简单介绍

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
Windows恶意软件20年“... 在Windows的早期年代,病毒游走于系统之间,偶尔删除文件(但被删除的文件几乎都是可恢复的),并弹...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
着眼MAC地址,解救无法享受D... 在安装了DHCP服务器的局域网环境中,每一台工作站在上网之前,都要先从DHCP服务器那里享受到地址动...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...