你的位置:首页 > 软件开发 > ASP.net > .Net开源数据库设计工具Mr.E For Linq (EF 6.1) 教程(二)级联删除和触发器

.Net开源数据库设计工具Mr.E For Linq (EF 6.1) 教程(二)级联删除和触发器

发布时间:2016-08-28 13:00:14
1.建立级联删除Mr.E的级联删除并非数据库自带那个级联删除,而是Mr.E自带的,所以它能触发你C#里面编写的触发器。首先,建立级联删除关系,如下图有两个表,UserInfo和UserDocument,UserDocument表依靠UserID字段,和UserInfo联系起来。现 ...

1.建立级联删除

Mr.E的级联删除并非数据库自带那个级联删除,而是Mr.E自带的,所以它能触发你C#里面编写的触发器。

首先,建立级联删除关系,如下图有两个表,UserInfo和UserDocument,

.Net开源数据库设计工具Mr.E For Linq (EF 6.1) 教程(二)级联删除和触发器

UserDocument表依靠UserID字段,和UserInfo联系起来。现在我要实现,当UserInfo里面的数据删除时,自动删除UserDocument表里面UserID=UserInfo.id的那些数据,应该怎么做呢?

首先,双击UserInfo打开它的属性编辑器,点击【级联删除】设置项,添加级联删除关系

.Net开源数据库设计工具Mr.E For Linq (EF 6.1) 教程(二)级联删除和触发器

.Net开源数据库设计工具Mr.E For Linq (EF 6.1) 教程(二)级联删除和触发器

然后编译数据库dll,我们去代码那里实验一下。

2.触发器

首先新建一个UserDocumentAction类,继承EntityDB.ActionCapture<Test.UserDocument>,作为UserDocument表的触发器

using System;using System.Collections.Generic;using System.Diagnostics;using System.Linq;using System.Text;using System.Threading.Tasks;namespace LinqTest1{  public class UserDocumentAction : EntityDB.ActionCapture<Test.UserDocument>  {    public override void BeforeInsert(object database, EntityDB.DatabaseModifyEventArg e)    {      Debug.WriteLine("UserDocument BeforeInsert");    }    public override void AfterInsert(object database, EntityDB.DatabaseModifyEventArg e)    {      var data = (Test.UserDocument)e.DataItem;      Debug.WriteLine(get='_blank'>string.Format("UserDocument发现有新的数据,id={0} FileName={1}" , data.id , data.FileName));    }    public override void BeforeUpdate(object database, EntityDB.DatabaseModifyEventArg e)    {          }    public override void AfterUpdate(object database, EntityDB.DatabaseModifyEventArg e)    {          }    public override void BeforeDelete(object database, EntityDB.DatabaseModifyEventArg e)    {      var db = (Test.DB.TestDB)database;      var data = (Test.UserDocument)e.DataItem;      //data只有id字段有值,所以要把所有字段的值都取出来,需要去数据库那里取一次      data = db.UserDocument.FirstOrDefault(m=>m.id == data.id);      Debug.WriteLine("数据即将删除:FileName=" + data.FileName + " Desc=" + data.Desc);    }    public override void AfterDelete(object database, EntityDB.DatabaseModifyEventArg e)    {      Debug.WriteLine("UserDocument AfterDelete");    }  }}

原标题:.Net开源数据库设计工具Mr.E For Linq (EF 6.1) 教程(二)级联删除和触发器

关键词:.NET

*特别声明:以上内容来自于网络收集,著作权属原作者所有,如有侵权,请联系我们: admin#shaoqun.com (#换成@)。