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

 
 
Опции темы Поиск в этой теме Опции просмотра
Старый 26.11.2007, 18:29   #1  
gl00mie is offline
gl00mie
Участник
MCBMSS
Most Valuable Professional
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии AXAWARD 2013
Лучший по профессии 2011
Лучший по профессии 2009
 
3,684 / 5798 (201) ++++++++++
Регистрация: 28.11.2005
Адрес: Москва
Записей в блоге: 3
! Преобразование boolean <-> NoYes в запросах
Наткнулся сегодня на один неприятный побочный эффект преобразования типов в запросах. В таблицах для полей-"флажков" обычно используют enum NoYes, при том что в коде как-то привычнее оперировать с типом boolean (хотя, вообще говоря, никто не мешает использовать enum boolean и для полей таблиц ). Так вот, если в запросе для поля с типом enum NoYes в качестве QueryBuildRange.value() указать значение true (с использованием queryValue(), конечно), то на СУБД вместо ожидаемой единички уйдет 255! Причем в зависимости от версии ядра выяснить это удастся на различных этапах. Так, в SP3 QueryBuildRange.toString() будет показывать значение range "true", и выловить этот косяк удастя лишь трассировкой SQL-операторов; а вот на KR3 увидеть это можно будет уже в самой Аксапте, которая в QueryBuildRange.toString() будет честно писать значение range "255". Такая же картина наблюдается и при указании значения NoYes::Yes при выборке по полю с типом enum boolean.
При этом если запрос по таблице table c полем flagField типа enum NoYes делать непосредственно из кода
X++:
select table where table.flagField == true;
то на СУБД в запросе уходит единичка, как и ожидается Проверялось на AX 3.0 SP3, AX 3.0 KR3.
PS. Что-то похожее касательно enum'ов уже обсуждалось, но явной корреляции с той темой я не увидел. Возможно, конечно, что тема более общая и связана с преобразованием значений различных enum'ов вообще, я не проверял.
За это сообщение автора поблагодарили: Russland (1).
 

Похожие темы
Тема Автор Раздел Ответов Посл. сообщение
Объясните что это <datasource name>_DS Андрей К. DAX: Программирование 8 09.04.2007 18:14
Ошибка "Значение <3> не найдено в MAP". Lysov DAX: Программирование 3 20.02.2007 18:24
Что такое "<имя-формы>_ds"? Valia DAX: База знаний и проекты 6 11.11.2003 14:26
Параметр коммандной строки -job=<s> vovayak DAX: Администрирование 11 17.10.2003 15:59
что-такое "<имя-формы>_ds"? Valia DAX: Программирование 3 21.08.2003 10:48

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

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

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