Хобрук: Ваш путь к мастерству в программировании

Firebird - возвращает количество полей, не равных нулю, используя выбор внутри SP

Мне нужно написать процедуру хранения Firebird, чтобы проверить значение 4 полей и вернуть количество только тех, которые не равны нулю.

Например, в псевдокоде:

  X = 0; //is the count variable

  if field_1 is not null then X = 1;
  if field_2 is not null then X = X + 1;
  if field_3 is not null then X = X + 1;
  if field_4 is not null then X = X + 1;

Но я хочу спросить, можно ли это сделать внутри одного Select?

Я использую Firebird 2.5


Ответы:


1

Если вы хотите получить эту сумму для каждой строки, используйте IIF, предложенная Веллиамом, подойдет.

Но если вы хотите получить только одну сумму по всем строкам, используйте агрегатную функцию COUNT с явным именем поля.

select count(Field_1) + count(Field_2) + count(Field_3) + count(Field_4)
   from SomeTable;

так как в этом случае он подсчитывает строки, в которых указанное поле не равно NULL.

11.04.2013
  • да, это было бы лучше, чем использовать две функции и длинный синтаксис Sum(IIF...)......спасибо 11.04.2013

  • 2

    Вы можете сделать это с помощью функции IIF, например:

    select IIF(Field_1 is null, 0, 1)
         + IIF(Field_2 is null, 0, 1)
         + IIF(Field_3 is null, 0, 1)
         + IIF(Field_4 is null, 0, 1)
      from SomeTable;
    
    11.04.2013
    Новые материалы

    Основы принципов S.O.L.I.D, Javascript, Git и NoSQL
    каковы принципы S.O.L.I.D? Принципы SOLID призваны помочь разработчикам создавать надежные, удобные в сопровождении приложения. мы видим пять ключевых принципов. Принципы SOLID были разработаны..

    Как настроить Selenium в проекте Angular
    Угловой | Селен Как настроить Selenium в проекте Angular Держите свое приложение Angular и тесты Selenium в одной рабочей области и запускайте их с помощью Mocha. В этой статье мы..

    Аргументы прогрессивного улучшения почти всегда упускают суть
    В наши дни в кругах веб-разработчиков много болтают о Progressive Enhancement — PE, но на самом деле почти все аргументы с обеих сторон упускают самую фундаментальную причину, по которой PE..

    Введение в Джанго Фреймворк
    Схема «работать умно, а не усердно» В этой и последующих статьях я познакомлю вас с тем, что такое фреймворк Django и как создать свое первое приложение с помощью простых и понятных шагов, а..

    Настольный ПК как «одно кольцо, чтобы править всеми» домашних компьютеров
    Вид после 9 месяцев использования С настольных компьютеров все началось, но в какой-то момент они стали «серверами», и мы все перешли на ноутбуки. В прошлом году я столкнулся с идеей настольных..

    Расширенные методы безопасности для VueJS: реализация аутентификации без пароля
    Руководство, которое поможет вам создавать безопасные приложения в долгосрочной перспективе Безопасность приложений часто упускается из виду в процессе разработки, потому что основная..

    стройный-i18следующий
    Представляем стройную оболочку для i18next. Эта библиотека, основанная на i18next, заключает экземпляр i18next в хранилище svelte и отслеживает события i18next, такие как languageChanged,..