Добро пожаловать, Гость. Пожалуйста, войдите или зарегистрируйтесь.
Не получили письмо с кодом активации?
Сентябрь 23, 2018, 06:49:29 pm

Автор Тема: Игнорирование измерения  (Прочитано 404 раз)

Оффлайн andrrreasss

  • Новичок
  • *
  • Сообщений: 14
  • Страна: ru
  • Рейтинг: +3/-0
    • Просмотр профиля
Игнорирование измерения
« : Апрель 28, 2018, 09:04:22 am »
Всем день добрый.  Что-то никак не соображу как сделать относительно простую задачу. Как проигнорировать одно из измерений? Пример такой, в плановых данных есть цифры только по одному из измерений, во втором NULL. В фактических, по двум измерениям.

Надо получить таблицу

Измерение1, Измерение2, ТутКолВоИзПлана, ТутКолВоИзФакта.

Как на первом скрине.

Я добавляю в формулу Sum(TOTAL <Измерение1> {$<[ВидОперации]={'План'}>} [Количество])

Но у меня добавляются записи с NULL по второму измерению. А они мне не нужны.

Код для тестовых данных

[ТаблицаФактов]:
Load * Inline [

Период|ВидОперации|Категория|ТоварнаяГруппа|Количество
2018-04-26|План|Аксессуары|NULL|4
2018-04-26|План|Белье|NULL|7
2018-04-26|План|Кожгалантерея|NULL|5
2018-04-26|План|Обувь|NULL|9
2018-04-26|План|Одежда|NULL|8
2018-04-26|План|Сумки|NULL|11
2018-04-26|Факт|Аксессуары|Перчатки|2
2018-04-26|Факт|Белье|Носки|1
2018-04-26|Факт|Кожгалантерея|Кошелек|1
2018-04-26|Факт|Обувь|Кеды|2
2018-04-26|Факт|Одежда|Джинсы|1
2018-04-26|Факт|Сумки|Клатч|2] (delimiter is '|');

Оффлайн admin

  • Administrator
  • Hero Member
  • *****
  • Сообщений: 1177
  • Страна: ru
  • Рейтинг: +127/-0
    • Просмотр профиля
Re: Игнорирование измерения
« Ответ #1 : Апрель 28, 2018, 11:16:42 am »
Все верно выводит.
для ядра клика null всего лишь товарная группа.
Нарисуйте в Excel, что необходимо получить?

Оффлайн andrrreasss

  • Новичок
  • *
  • Сообщений: 14
  • Страна: ru
  • Рейтинг: +3/-0
    • Просмотр профиля
Re: Игнорирование измерения
« Ответ #2 : Апрель 28, 2018, 12:06:08 pm »
Получить надо таблицу как на первом скрине.

Например есть план:

Обувь - 10

Есть факт:

Обувь, размер 41 - 1
Обувь, размер 42 - 3
Обувь, размер 45 - 2

Нужна таблица:

Обувь, 41 размер, план-10, факт 1
Обувь, 42 размер, план-10, факт 3
Обувь, 45 размер, план-10, факт 2





Неофициальный форум пользователей QlikView & Qlik Sense

Re: Игнорирование измерения
« Ответ #2 : Апрель 28, 2018, 12:06:08 pm »

Оффлайн admin

  • Administrator
  • Hero Member
  • *****
  • Сообщений: 1177
  • Страна: ru
  • Рейтинг: +127/-0
    • Просмотр профиля
Re: Игнорирование измерения
« Ответ #3 : Апрель 28, 2018, 12:35:00 pm »
Тогда либо модель разбить на две таблицы со связью по Дата-категория, либо сформировать одну таблицу с разнесенной суммой плана по категории на факт. То есть применить ту же самую связь в скрипте.

Оффлайн admin

  • Administrator
  • Hero Member
  • *****
  • Сообщений: 1177
  • Страна: ru
  • Рейтинг: +127/-0
    • Просмотр профиля
Re: Игнорирование измерения
« Ответ #4 : Май 14, 2018, 08:10:51 pm »
Пример с двумя таблицами:

[ТаблицаФактов]:

Load * Inline [
Период|ВидОперации|Категория|ТоварнаяГруппа|Количество
2018-04-26|План|Аксессуары|NULL|4
2018-04-26|План|Белье|NULL|7
2018-04-26|План|Кожгалантерея|NULL|5
2018-04-26|План|Обувь|NULL|9
2018-04-26|План|Одежда|NULL|8
2018-04-26|План|Сумки|NULL|11
2018-04-26|Факт|Аксессуары|Перчатки|2
2018-04-26|Факт|Белье|Носки|1
2018-04-26|Факт|Кожгалантерея|Кошелек|1
2018-04-26|Факт|Обувь|Кеды|2
2018-04-26|Факт|Одежда|Джинсы|1
2018-04-26|Факт|Сумки|Клатч|2] (delimiter is '|');

План:
NoConcatenate
load Период,Категория,Количество as КоличествоПлан Resident ТаблицаФактов where ВидОперации='План';
Факт:
NoConcatenate
load Период,Категория,ТоварнаяГруппа,Количество as КоличествоФакт Resident ТаблицаФактов where ВидОперации='Факт';
DROP Table ТаблицаФактов

Неофициальный форум пользователей QlikView & Qlik Sense

Re: Игнорирование измерения
« Ответ #4 : Май 14, 2018, 08:10:51 pm »