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

創(chuàng)新互聯(lián)是一家專(zhuān)注于網(wǎng)站設(shè)計(jì)制作、網(wǎng)站設(shè)計(jì)與策劃設(shè)計(jì),江油網(wǎng)站建設(shè)哪家好?創(chuàng)新互聯(lián)做網(wǎng)站,專(zhuān)注于網(wǎng)站建設(shè)10年,網(wǎng)設(shè)計(jì)領(lǐng)域的專(zhuān)業(yè)建站公司;建站業(yè)務(wù)涵蓋:江油等地區(qū)。江油做網(wǎng)站價(jià)格咨詢:13518219792
級(jí)聯(lián)刪除(cascading deletes)從父表中刪除外鍵時(shí)也會(huì)刪除子表中的行。如果在一個(gè)表的主鍵列上刪除了一些行,那么在啟用級(jí)聯(lián)刪除的情況下,將在相關(guān)表的任何外鍵列上刪除相同信息。
- ///
- /// 級(jí)聯(lián)刪除(從父表中刪除外鍵時(shí)也會(huì)刪除子表中的行)
- ///
- ///
- ///
- ///
- public static void CascadingDeletes (T TEntity) where T : class // where T : INotifyPropertyChanging, INotifyPropertyChanged
- {
- var _type = TEntity.GetType();
- var _prop = _type.GetProperties();
- //查找是否有“AssociationAttribute”標(biāo)記的屬性(Linq中有“AssociationAttribute”標(biāo)記的屬性代表外表)
- var _assolist = _prop.Where(
- c => c.GetCustomAttributes(true).Any(
- a => ((Attribute)a).GetType().Name == "AssociationAttribute") &
- c.PropertyType.IsGenericType);//該屬性必需是泛型
- //其他表有外鍵關(guān)聯(lián)的記錄
- if (_assolist.Count() > 0)
- {
- foreach (var _asso in _assolist)
- {
- var _items = _asso.GetValue(TEntity, null);
- var _tItems = _items.GetType();
- var _item = _tItems.GetProperty("Item");
- var _tItem = _item.PropertyType;
- var _countProp = _tItems.GetProperty("Count");//獲取泛型中的屬性“Count”
- if (_countProp == null)
- throw new Exception("Cannot find the property 'Count' in " + _items.ToString());
- var _count = (int)_countProp.GetValue(_items, null);//獲取關(guān)聯(lián)記錄的數(shù)量
- for (int i = 0; i < _count; i++)
- {
- var _value = _item.GetValue(_items, new object[] { i });
- CascadingDeletes(_value);//刪除其他表有外鍵關(guān)聯(lián)的記錄
- }
- }
- }
- try
- {
- DeleteByName(TEntity);//刪除沒(méi)外鍵關(guān)聯(lián)的記錄
- }
- catch (Exception ex)
- {
- throw ex;
- }
- }
我在用更通俗的語(yǔ)言為大家介紹一下什么時(shí)級(jí)聯(lián)刪除:例如員工表中一項(xiàng)數(shù)據(jù)是部門(mén)ID,部門(mén)ID是部門(mén)表的主鍵,如果是級(jí)聯(lián)刪除,當(dāng)刪除了部門(mén)A的時(shí)候,會(huì)把所有屬于部門(mén)A的員工都給刪除。Linq級(jí)聯(lián)刪除因?yàn)長(zhǎng)inq語(yǔ)言的復(fù)雜性,就會(huì)讓人感到更難實(shí)現(xiàn)。下面繼續(xù)上述代碼實(shí)現(xiàn)Linq級(jí)聯(lián)刪除。
- public static void DeleteByName (T TEntity) where T : class
- {
- var type = TEntity.GetType();
- var table = TableFactory.CreateTable(type );
- table.DeleteOnSubmit(TEntity);
- //Console.WriteLine("Delete:"+ TEntity.ToString());
- }
- public static class TableFactory
- {
- public static System.Data.Linq.Table CreateTable () where T : class
- {
- return Database.NWDB.GetTable ();
- }
- public static System.Data.Linq.ITable CreateTable (Type t)
- {
- return Database.NWDB.GetTable(t);
- }
- }
- public static class Database
- {
- private static DLinq.NWDBDataContext _NWDB = null;
- public static DLinq.NWDBDataContext NWDB
- {
- get
- {
- if (_NWDB == null)
- _NWDB = new DLinq.NWDBDataContext();
- return _NWDB;
- }
- }
- }
希望這篇Linq級(jí)聯(lián)刪除能給大家?guī)?lái)一些提示及幫助。
當(dāng)前題目:深度剖析linq級(jí)聯(lián)刪除
本文路徑:http://m.fisionsoft.com.cn/article/djesipj.html


咨詢
建站咨詢
