Axapta Dynamics AX 2009 X++;选择日期范围

Axapta Dynamics AX 2009 X++;选择日期范围,axapta,x++,microsoft-dynamics,ax,Axapta,X++,Microsoft Dynamics,Ax,我正在创建一个X++报告,要求用户可以在表单上进行多重选择,当他们单击“报告”菜单按钮时,会根据选择将值拉入 到目前为止,这是很容易的,我可以拉在Str范围,即订单号,项目id的等,但我想能够拉在一个日期范围的基础上选择 我使用了一些MorpX报告使用的方法,在X++报告中使用了3种关键方法 setQuerySortOrder SetQueryEnabled 主要的关键是, setQueryRange setQuery范围的代码如下: private void setQueryRange(Com

我正在创建一个X++报告,要求用户可以在表单上进行多重选择,当他们单击“报告”菜单按钮时,会根据选择将值拉入

到目前为止,这是很容易的,我可以拉在Str范围,即订单号,项目id的等,但我想能够拉在一个日期范围的基础上选择

我使用了一些MorpX报告使用的方法,在X++报告中使用了3种关键方法

setQuerySortOrder SetQueryEnabled

主要的关键是,

setQueryRange

setQuery范围的代码如下:

private void setQueryRange(Common _common)
{
    FormDataSource              fds;

    LogisticsControlTable       logisticsTable;
    QueryBuildDataSource        qbdsLogisticsTable;

    QueryBuildRange             qbrVanRun;
    str                         rangeVanRun;

    QueryBuildRange             qbrLogId;
    str                         rangeLogId;

    QueryBuildRange             qbrExpStartDate;
    str                         rangeExpStartDate;

    set                         vanRunSet       = new Set(Types::String);
    set                         logIdSet        = new Set(Types::String);
    set                         expStartDate    = new Set(Types::Date);

    str addRange(str _range, str _value, QueryBuildDataSource _qbds, int _fieldNum, Set _set = null)
    {
    str             ret = _range;
    QueryBuildRange qbr;
    ;

    if(_set && _set.in(_Value))
    {
        return ret;
    }

    if(strLen(ret) + strLen(_value) + 1 > 255)
    {
        qbr = _qbds.addRange(_fieldNum);
        qbr.value(ret);
        ret = '';
    }

    if(ret)
    {
        ret += ',';
    }

    if(_set)
    {
        _set.add(_value);
    }

    ret += _value;
    return ret;
}

switch(_common.TableId)
{
    case tableNum(LogisticsControlTable):

    qbdsLogisticsTable  = element.query().dataSourceTable(tableNum(LogisticsControlTable));
    qbrVanRun           = qbdsLogisticsTable.addRange(fieldNum(LogisticsControlTable, APMServiceCenterID));

    qbdsLogisticsTable  = element.query().dataSourceTable(tableNum(LogisticsControlTable));
    qbrLogId            = qbdsLogisticsTable.addRange(fieldNum(LogisticsControlTable, LogisticsId));

//       qbdsLogisticsTable  = element.query().dataSourceTable(tableNum(LogisticsControlTable));
//        qbrExpStartDate     = qbdsLogisticsTable.addRange(fieldNum(LogisticsControlTable, APMExpDateJobStart));

    fds = _common.dataSource();

    for(logisticsTable = fds.getFirst(true) ? fds.getFirst(true) : _common;
        logisticsTable;
        logisticsTable = fds.getNext())
    {
        rangeVanRun         = addrange(rangeVanRun, logisticsTable.APMServiceCenterID, qbdsLogisticsTable, fieldNum(LogisticsControlTable, APMServiceCenterID), vanRunSet);
        rangeLogID          = addrange(rangeLogID, logisticsTable.LogisticsId, qbdsLogisticsTable, fieldNum(LogisticsControlTable, LogisticsId), logIdSet);
//           rangeExpStartDate   = addrange(rangeExpStartdate,       logisticsTable.APMExpDateJobStart, qbdsLogisticsTable, fieldNum(LogisticsControlTable, APMExpDateJobStart), expStartDate);
    }



qbrLogId.value(rangeLogID);
    qbrVanRun.value(rangeVanRun);
    break;
}
}

使用
queryValue
为查询正确设置日期格式:

set expStartDate = new Set(Types::String);

rangeExpStartDate = addrange(rangeExpStartdate, queryValue(logisticsTable.APMExpDateJobStart), qbdsLogisticsTable, fieldNum(LogisticsControlTable, APMExpDateJobStart), expStartDate);

我遇到的问题是注释掉的行。范围不能为Type::Date,这会导致范围和值出现问题。我尝试添加另一个新的范围部分,但没有与Str相同的情况。我也尝试了date2str,但不确定将其放置在代码中的何处?嗨,Jan,我尝试过这个,但我得到了错误;错误11,参数“_range”与所需类型不兼容。因为它是日期而不是字符串。是否不会使用date2str?您是否注意到我的更改中的
queryValue
部分?这将日期格式化为适合查询的字符串。我昨天添加了这个,但仍然出现错误,我今天再试一次,结果成功了。再次感谢简,如果没有你的指导,我会迷失在MorpX中:)