zoukankan      html  css  js  c++  java
  • 报表Query中的DataSource间的关系

    在报表中,用Query做报表的数据源,如果有多个数据源,并且数据源之间要通过一定的字段关联起来,有两种方式
    1.将子数据源的Relations属性设为Yes,这样子数据源和父数据源之间的关系会根据物理表的关系自动建立
    2.手动在Relations节点下添加关系.
    这两种方式都没办法解决一个问题,父子数据源之间存在两种关联,一种是Nomal的,一种是Field Fixed.
    比如InventTrans和InventJournalTable这两个表之间有多个关系,都是通过字段TransRefId进行Nomal方式的关联,同时通过限定不同的TransType来定义一个Field Fixed关系,这样这两个表之间就形成了BOM,BOMLine,InventJournal等多个Ralations,在报表中如果想通过InventJournal这个关系取得两个表中的数据,用上述两种方式还真没办法实现(也许有,俺没找到),因为如果采用第一种方法,始终会采用默认的第一个关系(不知道怎么指定用InventJournal这个关系),而第二种方法没办法创建Field Fixed类型的关系.
    查看文档也没找到解决方案,没办法,只能重载了fetch方法,用代码Load特定的关系,代码如下:
    public boolean fetch()
    {
        boolean ret;
        QueryRun qr;
        DictRelation dict;
            ;
        qr 
    = new QueryRun(this);

        dict 
    = new DictRelation(tablenum(inventTrans));
        dict.loadNameRelation(
    "InventJournal");

        qr.query().dataSourceTable(tablenum(InventTrans)).addRelation(dict);
        ret 
    = super();
        
    return ret;
    }

    另外谴责一把右对齐,真搞不清楚Axapta为什么弄个右对齐出来,上述两个表的对应字段,如果按照默认安装,不调整全局类型的情况下,查不出数据,因为默认情况下,一个左对齐,一个右对齐,ft!
  • 相关阅读:
    z-index 应用简单总结
    Query插件
    jquery验证表单中的单选与多选
    SQL Server 如何读写数据
    JS中for循序中延迟加载实现动态效果
    linux 消息队列例子
    MongoDB查询文档
    Delphi语言最好的JSON代码库 mORMot学习笔记1(无数评论)
    CSS长度单位及区别 em ex px pt in
    ddd
  • 原文地址:https://www.cnblogs.com/Farseer1215/p/497973.html
Copyright © 2011-2022 走看看