在AX2009里新增了一个关键字CrossCompany,这个关键字让查询多个公司的数据的语法变得简洁,如下所示:

,salesTable.dataAreaId;
    }

    pause;

}

查看执行的SQL语句如下所示:

SQL 语句: SELECT * FROM SALESTABLE A [ID=1575, 已重用=否]

可以看出在增加了关键字CrossCompany之后执行的SQL语句已经没有DataAreaId的限定了。如何限定选择某几个公司那?比如只选择"001"和"002"公司。需要在关键字CrossCompany后面加一个Container变量限定一下。如下所示:

,salesTable.dataAreaId;
    }

    pause;

}

执行的SQL语句如下:

SQL 语句: SELECT * FROM SALESTABLE A WHERE (DATAAREAID IN (N'001',N'002') ) [ID=953, 已重用=否]

从上面可以看出,AX把限定Container里的内容翻译成了SQL里的IN语法。
关于跨公司查询的更多内容可以参照MSDN,上面有很多示例代码和更详尽的解释。
http://msdn.microsoft.com/en-us/library/cc634544.aspx

相关文章:

  • 2021-10-30
  • 2022-01-19
  • 2021-06-28
  • 2022-12-23
  • 2021-11-19
  • 2021-05-25
  • 2022-12-23
  • 2021-11-23
猜你喜欢
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2022-02-28
  • 2021-05-31
  • 2022-12-23
  • 2021-10-10
相关资源
相似解决方案