二开案例.服务插件.BeginOperationTransaction

栏目:云星空知识作者:金蝶来源:金蝶云社区发布:2024-09-23浏览:1

二开案例.服务插件.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>执行其他需要事务保存的...
点击下载文档
确认删除?
回到顶部
客服QQ
  • 客服QQ点击这里给我发消息