成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

深度剖析linq級聯刪除

開發 后端
Linq語言受到很多人的追捧,Linq的更新數據,插入數據等都有詳細的介紹,但是Linq級聯刪除好像被大家所忽視了,現在我就來為大家介紹實現Linq級聯刪除的方法。

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
責任編輯:阡陌 來源: CSDN
相關推薦

2009-09-17 15:22:38

LINQ to SQL

2009-09-15 13:30:54

linq級聯

2009-09-10 14:37:57

LINQ匿名類型

2009-09-16 16:59:05

LINQ to XML

2009-09-17 13:15:20

LINQ查詢

2009-09-09 14:40:43

Linq to sql

2009-09-09 16:21:31

Linq使用sqlme

2009-09-14 10:13:02

LINQ查詢操作

2009-09-14 15:12:40

LINQ to XML

2009-09-09 13:39:05

Linq用戶定義函數

2009-09-14 10:35:15

Linq內部執行原理

2009-09-08 16:20:12

LINQ to SQL

2009-09-16 09:56:42

LINQ to SQL

2009-09-08 15:39:13

Linq使用Inser

2009-09-17 09:20:34

Linq和dLinq區

2009-09-18 17:17:58

LINQ模型

2009-09-07 16:25:14

Linq To SQL

2009-09-10 15:35:07

LINQ查詢表達式

2009-09-11 09:48:27

Linq Lambda

2009-09-07 17:18:33

LINQ查詢表達式
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 欧美成人一级 | 婷婷色国产偷v国产偷v小说 | 色婷婷综合成人av | 亚洲精品乱码久久久久久久久 | 国产福利91精品一区二区三区 | 中文成人在线 | 国产综合在线视频 | 国产激情在线观看视频 | 久久久99国产精品免费 | 国产在线观看一区二区 | 亚洲一区二区av | 性高湖久久久久久久久3小时 | 91xh98hx 在线 国产 | 一区二区三区电影在线观看 | 欧美一级片在线观看 | 天天操夜夜操 | 久久狠狠 | 国产日韩欧美 | 中文字幕在线视频免费视频 | 一本色道精品久久一区二区三区 | 超碰成人av | 国产在线不卡 | 国产精品视频播放 | 亚洲精品成人av久久 | 一区二区三区国产视频 | 国产一区二区三区四区在线观看 | 一级黄色片网站 | 日韩欧美亚洲 | 成年免费大片黄在线观看岛国 | 成人影视网址 | 国内久久 | 浴室洗澡偷拍一区二区 | 人妖videosex高潮另类 | 免费观看色 | 国产美女在线观看 | 国产成人精品久久二区二区 | 国产精品99久久久久久久久久久久 | 在线免费观看毛片 | 一区二区三区在线播放 | 69亚洲精品| 欧美色性|