二开案例.单据插件.清除网控(冲突操作)

【应用场景】
特需应用场景下,强制清除网控(冲突操作)。
【案例演示】
采购订单列表,双击打开采购订单时,系统自动创建修改网控,通过插件的方式,清除网控。

【实现步骤】
<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>按指定的时间范围清除网控
二开案例.单据插件.清除网控(冲突操作)
【应用场景】特需应用场景下,强制清除网控(冲突操作)。【案例演示】采购订单列表,双击打开采购订单时,系统自动创建修改网控,通过插件的...
点击下载文档文档为doc格式
声明:除非特别标注,否则均为本站原创文章,转载时请以链接形式注明文章出处。如若本站内容侵犯了原著者的合法权益,可联系本站删除。
上一篇
已经是第一篇



