深度剖析linq级联删除
创始人
2024-06-07 02:30:22
0

Linq语言受到很多人的追捧,Linq的更新数据,插入数据等都有详细的介绍,但是Linq级联删除好像被大家所忽视了,现在我就来为大家介绍实现Linq级联删除的方法。

级联删除(cascading deletes)从父表中删除外键时也会删除子表中的行。如果在一个表的主键列上删除了一些行,那么在启用级联删除的情况下,将在相关表的任何外键列上删除相同信息。

  1. ///   
  2. /// 级联删除(从父表中删除外键时也会删除子表中的行)  
  3. /// 
  4.  
  5. ///   
  6. ///   
  7. ///   
  8. public static void CascadingDeletes(T TEntity) where T : class // where T : INotifyPropertyChanging, INotifyPropertyChanged  
  9. {  
  10. var _type = TEntity.GetType();  
  11. var _prop = _type.GetProperties();  
  12. //查找是否有“AssociationAttribute”标记的属性(Linq中有“AssociationAttribute”标记的属性代表外表)  
  13. var _assolist = _prop.Where(  
  14. c => c.GetCustomAttributes(true).Any(  
  15. a => ((Attribute)a).GetType().Name == "AssociationAttribute") &  
  16. c.PropertyType.IsGenericType);//该属性必需是泛型  
  17. //其他表有外键关联的记录  
  18. if (_assolist.Count() > 0)  
  19. {  
  20. foreach (var _asso in _assolist)  
  21. {  
  22. var _items = _asso.GetValue(TEntity, null);  
  23. var _tItems = _items.GetType();  
  24. var _item = _tItems.GetProperty("Item");  
  25. var _tItem = _item.PropertyType;  
  26. var _countProp = _tItems.GetProperty("Count");//获取泛型中的属性“Count”  
  27. if (_countProp == null)  
  28. throw new Exception("Cannot find the property 'Count' in " + _items.ToString());  
  29. var _count = (int)_countProp.GetValue(_items, null);//获取关联记录的数量  
  30. for (int i = 0; i < _count; i++)  
  31. {  
  32. var _value = _item.GetValue(_items, new object[] { i });  
  33. CascadingDeletes(_value);//删除其他表有外键关联的记录  
  34. }  
  35. }  
  36. }  
  37. try 
  38. {  
  39. DeleteByName(TEntity);//删除没外键关联的记录  
  40. }  
  41. catch (Exception ex)  
  42. {  
  43. throw ex;  
  44. }  

我在用更通俗的语言为大家介绍一下什么时级联删除:例如员工表中一项数据是部门ID,部门ID是部门表的主键,如果是级联删除,当删除了部门A的时候,会把所有属于部门A的员工都给删除。Linq级联删除因为Linq语言的复杂性,就会让人感到更难实现。下面继续上述代码实现Linq级联删除。

  1. public static void DeleteByName(T TEntity) where T : class 
  2. {  
  3. var type = TEntity.GetType();  
  4. var table = TableFactory.CreateTable(type );  
  5. table.DeleteOnSubmit(TEntity);  
  6. //Console.WriteLine("Delete:"+ TEntity.ToString());  
  7. }  
  8.  public static  class TableFactory  
  9.  {   
  10. public static System.Data.Linq.Table CreateTable() where T : class 
  11. {  
  12. return Database.NWDB.GetTable();  
  13. }  
  14. public static System.Data.Linq.ITable  CreateTable (Type t)   
  15. {  
  16. return Database.NWDB.GetTable(t);  
  17. }  
  18. }  
  19. public   static class Database  
  20. {  
  21. private static DLinq.NWDBDataContext _NWDB = null;  
  22. public static DLinq.NWDBDataContext NWDB  
  23. {  
  24. get 
  25. {  
  26. if (_NWDB == null)  
  27. _NWDB = new DLinq.NWDBDataContext();  
  28. return _NWDB;  
  29. }  
  30. }  
  31. }  

希望这篇Linq级联删除能给大家带来一些提示及帮助。

【编辑推荐】

  1. LINQ动态查询的实现浅析
  2. LINQ TO SQL动态修改表名称的实现浅析
  3. LINQ To SQL的一点讨论
  4. 浅析LINQ事务处理的实现
  5. 浅析DataSet和DataTable

相关内容

热门资讯

如何允许远程连接到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 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...