二开案例.服务插件.BeginOperationTransaction
【应用场景】
<1>抛异常中断操作。
<2>数据校验。
<3>输出交互异常。
<4>数据预处理。
<5>数据再加工。
<6>日志跟踪。
<7>执行其他需要事务保存的数据库操作。
<8>设置是否取消平台对本操作的内置处理。
<9>设置是否取消执行本操作所关联的表单服务。
【案例演示】
采购订单,审核操作,使用服务插件,更新数据。
【实现步骤】
<1>编写服务插件,代码如下。
using Kingdee.BOS.App.Data; using Kingdee.BOS.Core.DynamicForm.PlugIn; using Kingdee.BOS.Core.DynamicForm.PlugIn.Args; using Kingdee.BOS.Util; using System.ComponentModel; using System.Linq; namespace Jac.XkDemo.BOS.Business.PlugIn { /// <summary> /// 【服务插件】BeginOperationTransaction /// </summary> [Description("【服务插件】BeginOperationTransaction"), HotUpdate] public class BeginOperationTransactionOperationServicePlugIn : AbstractOperationServicePlugIn { public override void OnPreparePropertys(PreparePropertysEventArgs e) { base.OnPreparePropertys(e); e.FieldKeys.Add("F_Jac_Text"); } public override void BeginOperationTransaction(BeginOperationTransactionArgs e) { base.BeginOperationTransaction(e); // 调整当前操作的数据包(该数据包稍后平台会自动更新保存到数据库) var billNoField = this.BusinessInfo.GetBillNoField(); foreach (var dataEntity in e.DataEntitys) { dataEntity["F_Jac_Text"] = "来自数据包修改:" + dataEntity[billNoField.PropertyName]; } // 直接操作数据库 var ids = string.Join(",", e.DataEntitys.Select(o => o[0])); var sql = string.Format("/*dialect*/UPDATE T_PUR_POORDER SET FCHANGEREASON=N'来自数据库修改:'+FBILLNO WHERE FID IN ({0})", ids); DBUtils.Execute(Context, sql); } } }
<2>拷贝插件组件到应用站点的WebSite\Bin目录下,重启IIS。
<3>BOSIDE扩展采购订单,审核操作注册服务插件,保存元数据,开发完毕。
【功能验证】
<1>登录业务站点,打开采购订单编辑界面,点击审核,插件会给采购订单上的文本字段和备注字段更新数据,如下图。
---------------------------------------------------------------------------------------------------------
【金蝶云星空BOS二次开发案例演示】https://vip.kingdee.com/article/94751030918525696
二开案例.服务插件.BeginOperationTransaction
【应用场景】<1>抛异常中断操作。<2>数据校验。<3>输出交互异常。<4>数据预处理。<5>数据再加工。<6>日志跟踪。<7>执行其他需要事务保存的...
点击下载文档
本文2024-09-23 03:59:16发表“云星空知识”栏目。
本文链接:https://wenku.my7c.com/article/kingdee-k3cloud-162378.html
您需要登录后才可以发表评论, 登录登录 或者 注册
最新文档
热门文章