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. Web通过JS调用客户端

    代码实现==> <html> <head> <script language="javascript"> function Run(str ...

  2. 战胜忧虑<5>——运用亚里士多德法则

    运用亚里士多德法则 如果人们将忧虑的时间,用来寻找解决问题的答案,那忧虑就会在人们智慧的光芒下消失.那么当你面对忧虑时,应该怎么办理?答案是,我们一定要学会用下面三种分析问题的基本步骤来解决各种不同的 ...

  3. requestscope.contextpath和<%=request.getContextPath()%>有何区别?(待解答)

    问题1:requestscope.contextpath和<%=request.getContextPath()%>有何区别? 问题2:${requestscope.contextpath ...

  4. HTML标签使用特写

    页面定时刷新标签 //页面定时刷新 <meta http-equiv="> Input标记各种特殊用法 <%--禁止鼠标选择内容--%> <input id=& ...

  5. Chrome插件开发入门(二)——消息传递机制

    Chrome插件开发入门(二)——消息传递机制   由于插件的js运行环境有区别,所以消息传递机制是一个重要内容.阅读了很多博文,大家已经说得很清楚了,直接转一篇@姬小光 的博文,总结的挺好.后面附一 ...

  6. windows7修改双系统启动项名称、先后顺序、等待时间

    一.进入BCDEdit.exe  正常启动Windows 7 系统,点击“开始” -> “所有程序” -> “附件”,右击“命令提示符” -> “以管理员身份运行”(需要将操作当前用 ...

  7. spring学习笔记(转)

    [1]搭建环境 1.添加jar包 使用spring需要 sring.jarcommons-loggin.jar 如果使用aop组件需要 aspectjweaver.jaraspectjrt.jar 如 ...

  8. Codeforces Round #363 (Div. 2) One Bomb

    One Bomb 题意: 只有一个炸弹,并且一个只能炸一行和一列的'*',问最后能否炸完所以'*',如果可以输出炸弹坐标 题解: 这题做的时候真的没什么好想法,明知道b题应该不难,但只会瞎写,最后越写 ...

  9. php 预定义接口

    Traversable Traversable { } 作用:检测一个类是否可以使用 foreach 进行遍历的接口. php代码中不能用.只有内部的PHP类(用C写的类)才可以直接实现Travers ...

  10. dom4j-full.jar 解析 XML

    dom4j-full.jar 解析 XML public Document getDocument() throws DocumentException { SAXReader read=new SA ...