日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
深度剖析linq級聯(lián)刪除

Linq語言受到很多人的追捧,Linq的更新數(shù)據(jù),插入數(shù)據(jù)等都有詳細的介紹,但是Linq級聯(lián)刪除好像被大家所忽視了,現(xiàn)在我就來為大家介紹實現(xiàn)Linq級聯(lián)刪除的方法。

創(chuàng)新互聯(lián)是一家專注于網(wǎng)站設計制作、網(wǎng)站設計與策劃設計,江油網(wǎng)站建設哪家好?創(chuàng)新互聯(lián)做網(wǎng)站,專注于網(wǎng)站建設10年,網(wǎng)設計領(lǐng)域的專業(yè)建站公司;建站業(yè)務涵蓋:江油等地區(qū)。江油做網(wǎng)站價格咨詢:13518219792

級聯(lián)刪除(cascading deletes)從父表中刪除外鍵時也會刪除子表中的行。如果在一個表的主鍵列上刪除了一些行,那么在啟用級聯(lián)刪除的情況下,將在相關(guān)表的任何外鍵列上刪除相同信息。

 
 
 
  1. ///   
  2. /// 級聯(lián)刪除(從父表中刪除外鍵時也會刪除子表中的行)  
  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. //其他表有外鍵關(guān)聯(lián)的記錄  
  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);//獲取關(guān)聯(lián)記錄的數(shù)量  
  30. for (int i = 0; i < _count; i++)  
  31. {  
  32. var _value = _item.GetValue(_items, new object[] { i });  
  33. CascadingDeletes(_value);//刪除其他表有外鍵關(guān)聯(lián)的記錄  
  34. }  
  35. }  
  36. }  
  37. try 
  38. {  
  39. DeleteByName(TEntity);//刪除沒外鍵關(guān)聯(lián)的記錄  
  40. }  
  41. catch (Exception ex)  
  42. {  
  43. throw ex;  
  44. }  

我在用更通俗的語言為大家介紹一下什么時級聯(lián)刪除:例如員工表中一項數(shù)據(jù)是部門ID,部門ID是部門表的主鍵,如果是級聯(lián)刪除,當刪除了部門A的時候,會把所有屬于部門A的員工都給刪除。Linq級聯(lián)刪除因為Linq語言的復雜性,就會讓人感到更難實現(xiàn)。下面繼續(xù)上述代碼實現(xiàn)Linq級聯(lián)刪除。

 
 
 
  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級聯(lián)刪除能給大家?guī)硪恍┨崾炯皫椭?/p>
本文題目:深度剖析linq級聯(lián)刪除
分享地址:http://www.dlmjj.cn/article/djesipj.html