二开案例.单据插件.清除网控(冲突操作)
【应用场景】
特需应用场景下,强制清除网控(冲突操作)。
【案例演示】
采购订单列表,双击打开采购订单时,系统自动创建修改网控,通过插件的方式,清除网控。
【实现步骤】
<1>编写单据插件,代码如下。
using Kingdee.BOS.App.Data; using Kingdee.BOS.Core.Bill.PlugIn; using Kingdee.BOS.Core.DynamicForm.PlugIn.Args; using Kingdee.BOS.Util; using System; using System.ComponentModel; namespace Jac.XkDemo.BOS.Business.PlugIn { /// <summary> /// 【单据插件】清除网控(冲突操作) /// </summary> [Description("【单据插件】清除网控(冲突操作)"), HotUpdate] public class DeleteNetCtrlBillPlugIn : AbstractBillPlugIn { public override void BarItemClick(BarItemClickEventArgs e) { base.BarItemClick(e); if (e.BarItemKey.EqualsIgnoreCase("test")) { // 下面将以采购订单为例,演示4种应用场景下的清除网控方法 // <1>按指定的用户清除网控 var userId = this.Context.UserId; // 查询用户:SELECT * FROM T_SEC_USER var sql1 = string.Format("DELETE FROM T_BAS_NETWORKCTRLRECORDS WHERE FUSERID={0}", userId); DBUtils.Execute(this.Context, sql1); // <2>按指定单据的内码清除网控 var pkValue = Convert.ToInt32(this.View.Model.GetPKValue()); var netCtrlId = "903eafb2784042b5948fe9a245b5dddf"; // 查询采购订单的修改网控:SELECT * FROM T_BAS_NETWORKCTRLOBJECT WHERE FMETAOBJECTID='PUR_PurchaseOrder' AND FNUMBER='Edit' var sql2 = string.Format("DELETE FROM T_BAS_NETWORKCTRLRECORDS WHERE FNETCTRLID=N'{0}' AND FINTERID=N'{1}'", netCtrlId, pkValue); DBUtils.Execute(this.Context, sql2); // <3>按指定的时间范围清除网控 var endTime = DateTime.Now.AddHours(-1).ToString("yyyy-MM-dd HH:mm:ss"); // 删除1小时以前的所有网控 var sql3 = string.Format("DELETE FROM T_BAS_NETWORKCTRLRECORDS WHERE FTIME<='{0}' ", endTime); DBUtils.Execute(this.Context, sql3); // <4>按指定的业务对象清除网控 var formId = "PUR_PurchaseOrder"; // 采购订单的业务对象标识 var sql5 = string.Format(@"DELETE T_BAS_NETWORKCTRLRECORDS FROM T_BAS_NETWORKCTRLRECORDS a JOIN T_BAS_NETWORKCTRLOBJECT b ON a.FNETCTRLID=b.FID WHERE b.FMETAOBJECTID=N'{0}' ", formId); DBUtils.Execute(this.Context, sql5); this.View.ShowMessage("清除网控操作成功!"); } } } }
<2>拷贝插件组件到应用站点的WebSite\Bin目录下,重启IIS。
<3>BOSIDE扩展采购订单,菜单集合新增菜单项test,注册表单插件,保存元数据,开发完毕。
【功能验证】
<1>登录业务站点,从采购订单列表打开采购订单编辑界面,点击test,即可清除当前采购订单的修改网控。
---------------------------------------------------------------------------------------------------------
【金蝶云星空BOS二次开发案例演示】https://vip.kingdee.com/article/94751030918525696
二开案例.单据插件.清除网控(冲突操作)
【应用场景】特需应用场景下,强制清除网控(冲突操作)。【案例演示】采购订单列表,双击打开采购订单时,系统自动创建修改网控,通过插件的...
点击下载文档
本文2024-09-23 04:00:24发表“云星空知识”栏目。
本文链接:https://wenku.my7c.com/article/kingdee-k3cloud-162501.html
您需要登录后才可以发表评论, 登录登录 或者 注册
最新文档
热门文章