AX2009 的批处理操作我们是通过RunBaseBatch framework,我们所要做的事情就是继承RunBaseBatch class,实现里面该实现的方法来执行批处理。

AX2012 的批处理操作是采用SysOperation framework,SysOperation framework是采用运行WCF服务来运行批处理以及处理客户端与服务端的会话。

还有一个更大的不同就是编程的模式不同,在09,我们是继承RunBaseBatch class,所有的逻辑都混杂在一起,二12的模式采用的MVC模式(Model-View-
Controller)具体可以参考.net的MVC模式,这种模式的好处可以让代码更有健壮性,及松耦合,坏处 就是我们得写好几个类

现在具演示一个2012处理批处理的实例

按照上面图片的显示,我们需要创建4个类

首先,我们创建服务类,服务类需要继承 SysOperationServiceBase

class IWS_TestBatchService extends SysOperationServiceBase

{

}

添加一个方法,该方法的参数必须指定是哪个契约contract

public void getData(IWS_TestBatchContract _contract)
{
    ItemId                  formItemId;
    ;
    formItemId  =   _contract.parmFromItemId();
    //dosomething
}

第二个类 数据契约类

[
DataContractAttribute,//表示是一个数据契约类
SysOperationContractProcessingAttribute(classStr(IWS_TestBatchBuilder)),//这个属性指定与哪个Builder关联
SysOperationGroupAttribute('Item'      , "物料"   , '1')//可以多个组//相当于dialogGroup
]
class IWS_TestBatchContract implements SysOperationValidatable//实现该类,可以验证数据元素的合规性
{
    ItemId      itemid;
}

添加一个数据元素

[DataMemberAttribute,//表示该方法是一个元数据
//SysOperationLabelAttribute("物料编号"),//该元数据的标签
SysOperationDisplayOrderAttribute("1"),//在组里的位置
SysOperationGroupMemberAttribute("Item") ]//相当于dialogGroup
ItemId  parmItemId(ItemId   _itemId = itemId)
{
    itemId  =   _itemId;
    return itemId;
}

由于实现了SysOperationValidatable这个类,所以我们必须实现Validate方法

public boolean validate()
{
    //检查数据的合理性
    return true;
}

第三个类,就是Builder,也就是界面,该类应该继承SysOperationAutomaticUIBuilder

class IWS_TestBatchBuilder extends SysOperationAutomaticUIBuilder
{
    DialogField             fldFromItemId;
    IWS_TestBatchContract   batchContract;
}

private boolean itemId_modified(FormStringControl _control)//控件Modify方法
{
    boolean             ret = _control.modified();
    if(ret)
    {
        info("modify itemId");
    }
    return ret;
}

private void itemId_Lookup(FormStringControl _control)//控件lookup方法

{

ItemId                          itemId =    fldFromItemId.value();

SysTableLookup                  sysTableLookup;

Query                           query          = new Query();

QueryBuildDataSource            queryBuildDataSource;

QueryBuildDataSource            qbds1,qbds2;

;

queryBuildDataSource = query.addDataSource(tableNum(InventTable));

sysTableLookup = SysTableLookup::newParameters(tableNum(InventTable),_control);

sysTableLookup.addLookupfield(fieldNum(InventTable, ItemId));

sysTableLookup.addLookupfield(fieldNum(InventTable, ItemType));

sysTableLookup.parmQuery(query);

sysTableLookup.performFormLookup();

}

protected DialogField addDialogField(IdentifierName methodName, Object _dataContract=this.dataContractObject())//与契约的元数据进行一一绑定

{     DialogField ret;

ret = super(methodName, _dataContract);

switch(methodName)

{

case methodStr(IWS_TestBatchContract, parmItemId):

fldFromItemId = ret;

break;

}     return ret;

}

protected void buildGroup(SysOperationGroupInfo groupInfo, FormBuildGroupControl groupControl) //对控件的排版分配

{

super(groupInfo, groupControl);

if (groupControl.name() == 'Item')

{

groupControl.columns(3);

}

}

public void postBuild() //该方法非常关键,主要用来获取契约,然后可以对我们的控件进行事件的注册及相关的方法

{

super();

//获取数据契约信息     batchContract    =   this.controller().getDataContractObject(identifierStr('_dataContract'));

//得到数据契约的原数据,相当于09的getDialogField     fldFromItemId           =   this.bindInfo().getDialogField(batchContract,methodStr(IWS_TestBatchContract,parmItemId));

//注册我们刚刚创建的modify,lookup方法

fldFromItemId.registerOverrideMethod(     methodStr(FormStringControl,modified),     methodStr(IWS_TestBatchBuilder,itemId_modified),this);

fldFromItemId.registerOverrideMethod(     methodStr(FormStringControl,lookup),     methodStr(IWS_TestBatchBuilder,itemId_Lookup),this);

}

public void postRun()//此方法运行在POST BUILD之后,可以做一些后续逻辑的分配

{

FormStringControl      formStringControl;

int                    controlId;     ;

super();

fldFromItemId.enabled(true);

}

最后一步就是Controller,逻辑的入口,也应该继承SysOpSampleBaseController

class IWS_TestBatchController extends SysOpSampleBaseController
{
}

public static IWS_TestBatchController constuct() //该方法可以为了在实例化的时候与服务对象进行绑定

{

  IWS_TestBatchController controller;

  //通过参数将控制器和服务进行绑定

  controller =  new IWS_TestBatchController();

  controller.parmClassName(classStr(IWS_TestBatchService));

  controller.parmMethodName(methodStr(IWS_TestBatchService, getData));

return controller;

}

public void formInit() //该方法根据传递的对象对契约的元数据进行一些默认值的设置

{

IWS_TestBatchContract       dataContractInfo;

Common                      tmpcom;

InventTable                 inventTable;

;

dataContractInfo    =   this.getDataContractObject(identifierStr('_dataContract'));

dataContractInfo    =   this.getDataContractObject(identifierStr('_dataContract'));

tmpcom=  args.record();

if(tmpcom.TableId   ==  tableNum(InventTable))

{         inventTable           =   tmpcom as InventTable;         dataContractInfo.parmItemId(inventTable.ItemId);

}

//else if{}

}

public ClassDescription caption()//标题
{
    return "物料测试";
}

public static void main(Args args)

{

  IWS_TestBatchController  controller;

  controller = IWS_TestBatchController::constuct();

  //controller.parmArgs(args);     //是否有对象传递

  //controller.parmLoadFromSysLastValue(false);  //是否保存上一次的值

  //controller.formInit();//初始化对象及默认值

controller.startOperation();//开始操作

}

测试如图:

AX2012全新的批处理方式的更多相关文章

  1. MySql8.0+全新身份验证方式

    我们在安装MySql8.0+的版本时MySql将会询问我们是否选择全新的身份验证方式,如下图 ⒈第一个是MySql推荐我们使用的强密码加密模式来进行身份验证 MySql8支持基于SHA256改进的更强 ...

  2. 清理C盘系统垃圾文件-批处理方式

    很多时候安装软件越来越多,部分软件产生的临时文件.垃圾文件常常存在于C盘系统盘中:日积夜累直接导致可用的系统盘空间越来越小,直到没有多余的空间为止, 最后可能的结果是系统异常.软件无法正常运行:此时可 ...

  3. 【收藏】Android AutoLayout全新的适配方式, 堪称适配终结者

    来源:http://blog.csdn.net/lmj623565791/article/details/49990941 更多:Android屏幕适配全攻略(最权威的Google官方适配指导) 一. ...

  4. Android AutoLayout全新的适配方式 堪称适配终结者(转)

    一.概述 相信Android的开发者对于设配问题都比较苦恼,Google官方虽然给出了一系列的建议,但是想要单纯使用这些建议将设备很轻松的做好,还是相当困难的.个人也比较关注适配的问题,之前也发了几篇 ...

  5. jQuery选择器——全新的总结方式

    jQuery 选择器的总结 用于定位的选择器: 基本选择器:(用来进行绝对定位) $("#myELement")    选择id值等于myElement的元素,id值不能重复在文档 ...

  6. 使用批处理方式从svn 检出DEMO

    Branching in Subversion¶ FROM:https://dev.geogebra.org/trac/wiki/SubversionBranching Some people wan ...

  7. C 自删除技术---批处理方式

    #include<stdio.h> #include<windows.h>#pragma comment(linker, "/subsystem:\"win ...

  8. ASP.NET Core 6框架揭秘实例演示[23]:ASP.NET Core应用承载方式的变迁

    ASP.NET Core应用本质上就是一个由中间件构成的管道,承载系统将应用承载于一个托管进程中运行起来,其核心任务就是将这个管道构建起来.从设计模式的角度来讲,"管道"是构建者( ...

  9. ContentProvider官方教程(7)3种访问形式:批处理、异步访问、intent间接访问(临时URI权限)

    Alternative Forms of Provider Access Three alternative forms of provider access are important in app ...

随机推荐

  1. C语言中字符串常量到底存在哪了?

    常量存储总结局部变量.静态局部变量.全局变量.全局静态变量.字符串常量以及动态申请的内存区 1.局部变量存储在栈中2.全局变量.静态变量(全局和局部静态变量)存储在静态存储区3.new申请的内存是在堆 ...

  2. 如何添加WebService调用时的用户认证

    场景: 当把发布好的WebService地址或WSDL提供给调用方时,需要对方先进行身份的认证通过后才允许接口的进步访问.而不是公开的谁都可以调用. 解决: 1.在IIS中设置对应网站的目录访问权限. ...

  3. 黄聪:wp-setting.php文件详解

    描述:用于设置公共变量.加载 WP 的程序和类库(存储 WP 函数.类和核心内容所在文件夹的位置).用户无需修改此文件,但是可以通过修改 wp-config.php 文件来进行配置. 定义 WPINC ...

  4. PHP 打印调用函数入口地址(堆栈)

    今天网站出现一个BUG,然后直接在数据库类里面写日志,看是哪条SQL出了问题,SQL语句到是找到了,但是不知道这条SQL语句来自何处,于是就想啊,如果能有一个办法,查看当前正在运行的这个方法是被哪个方 ...

  5. ADF_General JSF系列1_创建一个简单的JSF Application

    2015-02-17 Creatd By BaoXinjian

  6. Form_通过Custom.pll新增菜单项(案例)

    2014-05-31 Created By BaoXinjian

  7. sax,Dom,等解析方式地址 ?

    Android中使用SAX对XMl文件进行解析 http://blog.csdn.net/developer_jiangqq/article/details/7197045 使用SAX技术对XML文档 ...

  8. oProfile 学习

    oProfile工具可以分析CPU的负载量 只要对目标程序加上 -g 后重新编译,即可用oProfile进行分析 例如在测试apache的性能时, 增加 -g 编译选项[crifan@localhos ...

  9. Opencv 2.4.9在Ubuntu下的配置与安装

    [原]Opencv 2.4.9在Ubuntu下的配置安装  Opencv 2.4.9在Ubuntu下的配置与安装 surgewong@gmail.com http://blog.csdn.net/su ...

  10. [ActionScript 3.0] LocalConnection示例

    下例包含两个 ActionScript 类,这两个类应当编译到两个单独的 SWF 文件中: 在 LocalConnectionSenderExample SWF 文件中,将创建 LocalConnec ...