AXForum  
Вернуться   AXForum > Microsoft Dynamics AX > DAX Blogs
All
Забыли пароль?
Зарегистрироваться Правила Справка Пользователи Сообщения за день Поиск

 
 
Опции темы Поиск в этой теме Опции просмотра
Старый 31.01.2019, 03:15   #1  
Blog bot is offline
Blog bot
Участник
 
25,475 / 846 (79) +++++++
Регистрация: 28.10.2006
View computed column to get OR for two flags
Источник: http://alexvoy.blogspot.com/2019/01/...r-for-two.html
==============

Nothing new, just to reiterate the basics.

Say, we need to add a computed column as a result of OR function over two other columns of Boolean type: wblPPOFirmDisableForSalesLine and wblPPOFirmDisableForTransferLine.



Create a new field wblPPOFirmDisable as Enum Computed field


and point it to the following method.




private static server str wblPPOFirmDisable(int _tableNum)
{
DictView ctView = new DictView(tableNum(wblPeggedRefTransOnHoldUnionView));
str sTransType1 = SysComputedColumn::comparisonField(identifierStr(wblPeggedRefTransOnHoldUnionView), identifierStr(wblSalesTableOnHoldView), fieldStr(wblSalesTableOnHoldView, wblPPOFirmDisableForSalesLine));
str sTransType2 = SysComputedColumn::comparisonField(identifierStr(wblPeggedRefTransOnHoldUnionView), identifierStr(wblSalesTableOnHoldView), fieldStr(wblSalesTableOnHoldView, wblPPOFirmDisableForTransferLine));
str sRet = '';

sRet =
SysComputedColumn::or2
(
SysComputedColumn::equalExpression(sTransType1, SysComputedColumn::returnLiteral(NoYes::Yes)),
SysComputedColumn::equalExpression(sTransType2, SysComputedColumn::returnLiteral(NoYes::Yes))
);
sRet =
SysComputedColumn::if(sRet, SysComputedColumn::returnLiteral(NoYes::Yes), SysComputedColumn::returnLiteral(NoYes::No));

return sRet;
}


The whole point is to create a string with an SQL statement as a result in static method. There are a lot of standard functions in SysComputedColumn class aiming to help with syntax.

As you can see in this example it is not enough to get a logical comparison result at the first sRet assigning. The latter must be converted explicitly to an SQL string as it goes at the second step.

Finally we get the following string as a part of the whole SQL statement.

CASE WHEN (T1.WBLPPOFIRMDISABLEFORSALESLINE = 1) OR (T1.WBLPPOFIRMDISABLEFORTRANSFERLINE = 1) THEN 1 ELSE 0 END


Источник: http://alexvoy.blogspot.com/2019/01/...r-for-two.html
__________________
Расскажите о новых и интересных блогах по Microsoft Dynamics, напишите личное сообщение администратору.
 

Похожие темы
Тема Автор Раздел Ответов Посл. сообщение
Запретить пересчет computed column у View kitty DAX: Программирование 4 30.01.2018 12:40
dynamicsaxbi: Better together: Microsoft Dynamics AX 2012 R2 and SQL Server Power View Blog bot DAX Blogs 0 12.12.2012 13:11
axtadka: Get Column Name from Column Number of Microsoft Excel in Dynamics AX 2009 by X++ Code Blog bot DAX Blogs 0 17.11.2012 11:12
daxmusings: Computed View Columns in AX 2012 Blog bot DAX Blogs 5 19.10.2011 13:55
emeadaxsupport: Setting marked Alerts to Read (or Unread) the “Unread” column doesn't get updated properly Blog bot DAX Blogs 0 31.08.2011 18:11

Ваши права в разделе
Вы не можете создавать новые темы
Вы не можете отвечать в темах
Вы не можете прикреплять вложения
Вы не можете редактировать свои сообщения

BB коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход

Рейтинг@Mail.ru
Часовой пояс GMT +3, время: 07:10.
Powered by vBulletin® v3.8.5. Перевод: zCarot
Контактная информация, Реклама.