1.建立级联删除Mr.E的级联删除并非数据库自带那个级联删除,而是Mr.E自带的,所以它能触发你C#里面编写的触发器。首先,建立级联删除关系,如下图有两个表,UserInfo和UserDocument,UserDocument表依靠UserID字段,和UserInfo联系起来。现 ...
1.建立级联删除
Mr.E的级联删除并非数据库自带那个级联删除,而是Mr.E自带的,所以它能触发你C#里面编写的触发器。
首先,建立级联删除关系,如下图有两个表,UserInfo和UserDocument,
UserDocument表依靠UserID字段,和UserInfo联系起来。现在我要实现,当UserInfo里面的数据删除时,自动删除UserDocument表里面UserID=UserInfo.id的那些数据,应该怎么做呢?
首先,双击UserInfo打开它的属性编辑器,点击【级联删除】设置项,添加级联删除关系
然后编译数据库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
(#换成@)。