快速业务通道

LINQ学习笔记:LINQ to SQL实体类

作者 佚名技术 来源 NET编程 浏览 发布时间 2012-03-13

这表示当加载Customer的时候同时加载那些Price金额大于456的Purchases.

更新

LINQ to SQL会保持你对实体做的变更痕迹并且允许你调用DataContext.SubmitChanges将它们写回数据库.Table<>类上的InsertOnSubmit和DeleteOnSubmit分别用于新增或者删除表中的一行. 以下示例演示如何使用它们:

   1: var dataContext = new CustomDataContext (“connectionString”);
   2:  
   3:     Customer cust = new Customer { ID=1000, Name=“Bloggs” };
   4:  
   5:     dataContext.Customers.InsertOnSubmit(cust);
   6:  
   7:     dataContext.SubmitChanges();

我们也可以在读取行资料之后,更新然后删除它:

   1: var dataContext = new CustomDataContext (“connectionString”);
   2:  
   3: Customer cust = dataContext.Customers.Single(c => c.ID == 1000);
   4:  
   5: cust.Name = “Bloggs2″;
   6:  
   7: dataContext.SubmitChanges();    // 更新customer
   8:  
   9: dataContext.Customers.DeleteOnSubmit (cust);
  10:  
  11: dataContext.SubmitChanges();    // 删除customer

DataContext.SubmitChanges收集所有自从DataContext创建以来(或者上次调用SubmitChanges以来)的变更,然后执行对应的SQL语句将他们写回数据库.所有的语句都将被放在一个Transaction当中来运行.

你也可以通过调用Add将一个新行加入到一个EntitySet当中,LINQ to SQL会自动设置对应的外键:

   1: var p1 = new Purchase { ID=100, Description=“Bike”,Price=500 };
   2:  
   3: var p2 = new Purchase { ID=101, Description=“Tools”,Price=100 };
   4:  
   5: Customer cust = dataContext.Customers.Single(c => c.ID == 1);
   6:  
   7: cust.Purchases.Add (p1);
   8:  
   9: cust.Purchases.Remove (p2);
  10:  
  11: dataContext.SubmitChanges();

在此例子中, LINQ to SQL自动将1写入到各个新的purchase中的CustomerID列, 原因就是因为我们定义的Purchases属性:

   1: [Association (Storage=“_Purchases”,
   2:  
   3:               OtherKey=“CustomerID”)]
   4:  
   5: public EntitySet Purchases
   6:  
   7: { get {…} set {…}

凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

分享到: 更多

Copyright ©1999-2011 厦门凌众科技有限公司 厦门优通互联科技开发有限公司 All rights reserved

地址(ADD):厦门软件园二期望海路63号701E(东南融通旁) 邮编(ZIP):361008

电话:0592-5908028 传真:0592-5908039 咨询信箱:web@lingzhong.cn 咨询OICQ:173723134

《中华人民共和国增值电信业务经营许可证》闽B2-20100024  ICP备案:闽ICP备05037997号