|
![]() |
#1 |
Administrator
|
Цитата:
__________________
Возможно сделать все. Вопрос времени |
|
![]() |
#2 |
Участник
|
NotExists как тут поможет? мне наоборот надо, чтобы запись в С искалась. либо поле из B берется Для ограничения выбора, либо если не нашлось B для A, то берется 0.
А view здесь как ? |
|
![]() |
#3 |
Участник
|
В 2012-й можно во вьюхе создать Computed Column, в котором указать для расчета функцию IsNull()
Т.е. создать вью на основании соединения таблиц A и B и в запросе использовать эту вьюху. Условие для С будет X++: while select view join C where C.RelationQQQ == view.RelationQQQ && C.RelationTTT == view.ComputedColumn
__________________
Axapta v.3.0 sp5 kr2 |
|
![]() |
#4 |
Administrator
|
Цитата:
Но тогда неясен запрос. Если таблица B связывается с C по INNER JOIN - то тогда какие могут быть NULL-ы? NULL-ов в АХ нет. Они могут образовываться только от LEFT OUTER JOIN, но именно эти записи отбираются notexists join-ом
__________________
Возможно сделать все. Вопрос времени |
|
![]() |
#5 |
Участник
|
Все крутится в отчете и запрос еще соединения содержит, не очень удобно. Нельзя в коде через какой-нибудь == (case B.PoleTTT isnull '' default B.PoleTTT ) ?
а вот так понятнее или только усугубит: таблица A с прицепами для автомобилей. К ней привязана таблица B с автомобилями, именно в таблице B указан параметр определяющий стоимость из таблицы С для прицепа из А. В таблице С ищем стоимость- мы нашли наш прицеп в ней, но необходимо еще учесть параметр из B. Если автомобиль к прицепу не привязали, то берем по нашему прицепу по умолчанию параметр "оранжевый" и стоимость для него. |
|
![]() |
#6 |
Administrator
|
Цитата:
Сообщение от trudel
![]() Все крутится в отчете и запрос еще соединения содержит, не очень удобно. Нельзя в коде через какой-нибудь == (case B.PoleTTT isnull '' default B.PoleTTT ) ?
а вот так понятнее или только усугубит: таблица A с прицепами для автомобилей. К ней привязана таблица B с автомобилями, именно в таблице B указан параметр определяющий стоимость из таблицы С для прицепа из А. В таблице С ищем стоимость- мы нашли наш прицеп в ней, но необходимо еще учесть параметр из B. Если автомобиль к прицепу не привязали, то берем по нашему прицепу по умолчанию параметр "оранжевый" и стоимость для него. ![]() Поэтому по сути - наверное с ходу не подскажу другой идеи, кроме как разбить запросы.
__________________
Возможно сделать все. Вопрос времени |
|
![]() |
#7 |
Участник
|
ну не может быть, чтобы у такой простой задачи не было простого решения...
== (case B.PoleTTT isnull '' default B.PoleTTT ) ?.. ![]() |
|
![]() |
#8 |
NavAx
|
Цитата:
Как вам правильно подсказывают, разбейте на несколько запросов. Это не SQL, в котором нужно одним монструозным запросом все перелопатить. И я бы так базу не проектировал, конечно.
__________________
Isn't it nice when things just work? |
|
![]() |
#9 |
Участник
|
|
|
![]() |
#10 |
Участник
|
Как уже сдесь говорили в Ах поля не могут быть null следовательно этой задачи в этом языке быть не может. Если вы хотите чтобы вам помогли опишите ЧТО вы хотите достичь. а не КАК вы этого хотите достичь и вам обязательно помогут. Ну или постараются.
|
|
|
Опции темы | Поиск в этой теме |
Опции просмотра | |
|