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

 
 
Опции темы Поиск в этой теме Опции просмотра
Старый 24.04.2015, 14:26   #1  
sukhanchik is offline
sukhanchik
Administrator
Аватар для sukhanchik
MCBMSS
Злыдни
Лучший по профессии 2015
Лучший по профессии AXAWARD 2013
Лучший по профессии 2011
Лучший по профессии 2009
 
3,342 / 3563 (125) ++++++++++
Регистрация: 13.06.2004
Адрес: Москва
Цитата:
Сообщение от sukhanchik Посмотреть сообщение
notexists join
Цитата:
Сообщение от trudel Посмотреть сообщение
NotExists как тут поможет? мне наоборот надо, чтобы запись в С искалась. либо поле из B берется Для ограничения выбора, либо если не нашлось B для A, то берется 0.

А view здесь как ?
Сорри, я невнимательно вчитался.
Но тогда неясен запрос. Если таблица B связывается с C по INNER JOIN - то тогда какие могут быть NULL-ы?
NULL-ов в АХ нет.
Они могут образовываться только от LEFT OUTER JOIN, но именно эти записи отбираются notexists join-ом
__________________
Возможно сделать все. Вопрос времени
Старый 24.04.2015, 15:00   #2  
trudel is offline
trudel
Участник
 
52 / 10 (1) +
Регистрация: 17.04.2015
Все крутится в отчете и запрос еще соединения содержит, не очень удобно. Нельзя в коде через какой-нибудь == (case B.PoleTTT isnull '' default B.PoleTTT ) ?

а вот так понятнее или только усугубит: таблица A с прицепами для автомобилей. К ней привязана таблица B с автомобилями, именно в таблице B указан параметр определяющий стоимость из таблицы С для прицепа из А. В таблице С ищем стоимость- мы нашли наш прицеп в ней, но необходимо еще учесть параметр из B. Если автомобиль к прицепу не привязали, то берем по нашему прицепу по умолчанию параметр "оранжевый" и стоимость для него.
Старый 24.04.2015, 15:15   #3  
sukhanchik is offline
sukhanchik
Administrator
Аватар для sukhanchik
MCBMSS
Злыдни
Лучший по профессии 2015
Лучший по профессии AXAWARD 2013
Лучший по профессии 2011
Лучший по профессии 2009
 
3,342 / 3563 (125) ++++++++++
Регистрация: 13.06.2004
Адрес: Москва
Цитата:
Сообщение от trudel Посмотреть сообщение
Все крутится в отчете и запрос еще соединения содержит, не очень удобно. Нельзя в коде через какой-нибудь == (case B.PoleTTT isnull '' default B.PoleTTT ) ?

а вот так понятнее или только усугубит: таблица A с прицепами для автомобилей. К ней привязана таблица B с автомобилями, именно в таблице B указан параметр определяющий стоимость из таблицы С для прицепа из А. В таблице С ищем стоимость- мы нашли наш прицеп в ней, но необходимо еще учесть параметр из B. Если автомобиль к прицепу не привязали, то берем по нашему прицепу по умолчанию параметр "оранжевый" и стоимость для него.
Сумбурно конечно ... Такие вещи обычно бьются на 2 запроса. Это и шустрее и лечге потом правится и удобнее для многопользовательской БД.
Поэтому по сути - наверное с ходу не подскажу другой идеи, кроме как разбить запросы.
__________________
Возможно сделать все. Вопрос времени
Старый 24.04.2015, 15:31   #4  
trudel is offline
trudel
Участник
 
52 / 10 (1) +
Регистрация: 17.04.2015
ну не может быть, чтобы у такой простой задачи не было простого решения...
== (case B.PoleTTT isnull '' default B.PoleTTT ) ?..
Старый 27.04.2015, 07:46   #5  
macklakov is offline
macklakov
NavAx
Аватар для macklakov
 
2,347 / 996 (38) +++++++
Регистрация: 03.04.2002
Цитата:
Сообщение от trudel Посмотреть сообщение
ну не может быть, чтобы у такой простой задачи не было простого решения...
== (case B.PoleTTT isnull '' default B.PoleTTT ) ?..
Это не задача, а идиома из другого языка, которую вы пытаетесь перевести слово в слово. Поэтому еще раз повторюсь. X++ запросы лишь внешне напоминают SQL, но это не SQL.
Как вам правильно подсказывают, разбейте на несколько запросов. Это не SQL, в котором нужно одним монструозным запросом все перелопатить.
И я бы так базу не проектировал, конечно.
__________________
Isn't it nice when things just work?
Старый 27.04.2015, 09:20   #6  
maldini is offline
maldini
Участник
 
103 / 30 (2) +++
Регистрация: 06.03.2007
Адрес: москва
Цитата:
Сообщение от trudel Посмотреть сообщение
ну не может быть, чтобы у такой простой задачи не было простого решения...
== (case B.PoleTTT isnull '' default B.PoleTTT ) ?..
Если очень хочется SQL запрос, то есть возможность это сделать прямым запросом в БД.
Старый 27.04.2015, 10:18   #7  
skuull is offline
skuull
Участник
Most Valuable Professional
Лучший по профессии 2014
 
700 / 752 (27) +++++++
Регистрация: 08.03.2013
Адрес: ХЗ
Цитата:
Сообщение от maldini Посмотреть сообщение
Если очень хочется SQL запрос, то есть возможность это сделать прямым запросом в БД.
Из-за таких чудесных советов и такого прелестного подхода мы и имеем в итоге кучу кода на который нельзя смотреть без слез не говоря уже о его поддрежке.

Правильно, не надо тратить время на изучение никому ненужного языка есть же c# пишите на нем и подключайте библиотеки!
Старый 27.04.2015, 20:37   #8  
trudel is offline
trudel
Участник
 
52 / 10 (1) +
Регистрация: 17.04.2015
Цитата:
Сообщение от skuull Посмотреть сообщение
Правильно, не надо тратить время на изучение никому ненужного языка есть же c# пишите на нем и подключайте библиотеки!
помогите изучить. Книги на русском дают элементарные сведения, в справке на английском порой и не знаешь что искать. короче гуглю по вашему форуму и так учусь. что не нагуглю - спрашиваю.
Есть enum поля. делаю outer join с таблицей, содержащей их, для отчета. В итоге отчет выводит там где соединения не произошло все равно первое(0) значение енума, а должен пустое. Каким образом это сделать. При заполнении поля проверять поле "неенум типа" этой таблицы и если оно пустое, то тогда и енум поля заполнять пустым?
Старый 27.04.2015, 10:49   #9  
macklakov is offline
macklakov
NavAx
Аватар для macklakov
 
2,347 / 996 (38) +++++++
Регистрация: 03.04.2002
Цитата:
Сообщение от maldini Посмотреть сообщение
Если очень хочется SQL запрос, то есть возможность это сделать прямым запросом в БД.
А права доступа вы как будете к такому решению привинчивать? Особенно record level? Как вы будете отслеживать изменения в схеме данных? Ждать пока в runtime сбойнет?
__________________
Isn't it nice when things just work?
Старый 27.04.2015, 11:10   #10  
maldini is offline
maldini
Участник
 
103 / 30 (2) +++
Регистрация: 06.03.2007
Адрес: москва
Цитата:
Сообщение от macklakov Посмотреть сообщение
А права доступа вы как будете к такому решению привинчивать? Особенно record level? Как вы будете отслеживать изменения в схеме данных? Ждать пока в runtime сбойнет?
У человека было большое желание написать запрос используя синтаксис SQL. Я подсказал как это можно сделать. Правильно это или нет это уже другой вопрос.
Старый 27.04.2015, 10:25   #11  
skuull is offline
skuull
Участник
Most Valuable Professional
Лучший по профессии 2014
 
700 / 752 (27) +++++++
Регистрация: 08.03.2013
Адрес: ХЗ
Цитата:
Сообщение от trudel Посмотреть сообщение
ну не может быть, чтобы у такой простой задачи не было простого решения...
== (case B.PoleTTT isnull '' default B.PoleTTT ) ?..
Как уже сдесь говорили в Ах поля не могут быть null следовательно этой задачи в этом языке быть не может. Если вы хотите чтобы вам помогли опишите ЧТО вы хотите достичь. а не КАК вы этого хотите достичь и вам обязательно помогут. Ну или постараются.
Старый 27.04.2015, 10:39   #12  
S.Kuskov is offline
S.Kuskov
Участник
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
 
3,449 / 1792 (66) ++++++++
Регистрация: 28.04.2007
Адрес: Калуга
Цитата:
Сообщение от skuull Посмотреть сообщение
опишите ЧТО вы хотите достичь.
Цитата:
Сообщение от trudel Посмотреть сообщение
таблица A с прицепами для автомобилей. К ней привязана таблица B с автомобилями, именно в таблице B указан параметр определяющий стоимость из таблицы С для прицепа из А. В таблице С ищем стоимость- мы нашли наш прицеп в ней, но необходимо еще учесть параметр из B. Если автомобиль к прицепу не привязали, то берем по нашему прицепу по умолчанию параметр "оранжевый" и стоимость для него.
Если очень надо, то в AX2009 результат двух запросов можно объединить в UNION.
 

Похожие темы
Тема Автор Раздел Ответов Посл. сообщение
Множественные запросы по DataArea и VirtualDataAreaList Dreadlock DAX: Программирование 11 24.07.2012 11:43
Открытая сумма по счету-фактуре - как правильно вычислить? IKA DAX: Программирование 7 21.03.2011 19:46
Запросы / Итоги для ЗПР Prophetic DAX: Программирование 5 02.08.2010 15:13
оптимизируем запросы. SHiSHok DAX: Программирование 18 13.09.2009 21:26
Запросы в Аксапта ibc DAX: Программирование 5 08.08.2005 22:47

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

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

Рейтинг@Mail.ru
Часовой пояс GMT +3, время: 06:00.