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

创新互联是一家专注于网站设计制作、网站设计与策划设计,江油网站建设哪家好?创新互联做网站,专注于网站建设10年,网设计领域的专业建站公司;建站业务涵盖:江油等地区。江油做网站价格咨询:13518219792
级联删除(cascading deletes)从父表中删除外键时也会删除子表中的行。如果在一个表的主键列上删除了一些行,那么在启用级联删除的情况下,将在相关表的任何外键列上删除相同信息。
- ///
 - /// 级联删除(从父表中删除外键时也会删除子表中的行)
 - ///
 - ///
 - ///
 - ///
 - public static void CascadingDeletes (T TEntity) where T : class // where T : INotifyPropertyChanging, INotifyPropertyChanged
 - {
 - var _type = TEntity.GetType();
 - var _prop = _type.GetProperties();
 - //查找是否有“AssociationAttribute”标记的属性(Linq中有“AssociationAttribute”标记的属性代表外表)
 - var _assolist = _prop.Where(
 - c => c.GetCustomAttributes(true).Any(
 - a => ((Attribute)a).GetType().Name == "AssociationAttribute") &
 - c.PropertyType.IsGenericType);//该属性必需是泛型
 - //其他表有外键关联的记录
 - 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);//获取关联记录的数量
 - for (int i = 0; i < _count; i++)
 - {
 - var _value = _item.GetValue(_items, new object[] { i });
 - CascadingDeletes(_value);//删除其他表有外键关联的记录
 - }
 - }
 - }
 - try
 - {
 - DeleteByName(TEntity);//删除没外键关联的记录
 - }
 - catch (Exception ex)
 - {
 - throw ex;
 - }
 - }
 
我在用更通俗的语言为大家介绍一下什么时级联删除:例如员工表中一项数据是部门ID,部门ID是部门表的主键,如果是级联删除,当删除了部门A的时候,会把所有属于部门A的员工都给删除。Linq级联删除因为Linq语言的复杂性,就会让人感到更难实现。下面继续上述代码实现Linq级联删除。
- 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级联删除能给大家带来一些提示及帮助。
                网站题目:深度剖析linq级联删除
                
                当前路径:http://www.csdahua.cn/qtweb/news43/242443.html
            
成都网站优化推广公司_创新互联,为您提供网站制作、微信小程序、网站内链、营销型网站建设、关键词优化、网站改版
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网