WedX - журнал о программировании и компьютерных науках

Как отобразить заметку, если строки не существует? SQL-сервер

Я хочу отобразить все номера телефонов моего customer(Customertable).

Но если номера телефона нет, потому что клиент его не оставил, я хочу отобразить примечание «Нет номера телефона».

Я пробовал это с помощью команды

Select phonenumber 
From Customers
if phonenumber is NUll RAISEERROR 'No phonenumber'  -error

Но я получаю сообщение об ошибке:

"Номер телефона" не является допустимым именем столбца

и я предполагаю, что RAISEERROR также не является правильным способом отображения заметки (?!)

Пожалуйста помоги

Извините за плохой английский.

17.11.2016

  • Возможно, имя столбца другое? 17.11.2016

Ответы:


1

Почему бы просто не использовать coalesce для возврата первого ненулевого значения?

SELECT
    COALESCE(phonenumber, 'no phone number')
FROM customers
17.11.2016

2

RAISEEROR выглядит довольно брутально.

Вы можете сделать что-то вроде этого:

SELECT COALESCE(MAX(phonenumber), 'No phonenumber')
FROM Customers
WHERE CustomerId = @CustomerId;

Цель MAX() — вернуть одну строку для данного клиента.

Однако такая логика должна быть на уровне приложения и, возможно, не встроена в запрос.

17.11.2016

3

Вы можете попробовать это, я не знаю, что вы имеете в виду под отсутствием номера телефона, он может быть нулевым или пустым символом, так что это мои предположения:

Select case when phonenumber is null or phonenumber ="" then
'No phonenumber' 
else phonenumber end
 FROM Customers
17.11.2016
  • Сделайте это phonenumber = ''. Двойные кавычки для псевдонимов. 17.11.2016

  • 4

    Вы можете использовать функцию ISNULL

    ISNULL (проверочное_выражение, замещающее_значение)

    Описание можно найти в MSDN.

    Я надеюсь, что это поможет вам

    SELECT
       ISNULL(phonenumber, 'no phone number')
    FROM customers
    
    17.11.2016
    Новые материалы

    Как проанализировать работу вашего классификатора?
    Не всегда просто знать, какие показатели использовать С развитием глубокого обучения все больше и больше людей учатся обучать свой первый классификатор. Но как только вы закончите..

    Работа с цепями Маркова, часть 4 (Машинное обучение)
    Нелинейные цепи Маркова с агрегатором и их приложения (arXiv) Автор : Бар Лайт Аннотация: Изучаются свойства подкласса случайных процессов, называемых дискретными нелинейными цепями Маркова..

    Crazy Laravel Livewire упростил мне создание электронной коммерции (панель администратора и API) [Часть 3]
    Как вы сегодня, ребята? В этой части мы создадим CRUD для данных о продукте. Думаю, в этой части я не буду слишком много делиться теорией, но чаще буду делиться своим кодом. Потому что..

    Использование машинного обучения и Python для классификации 1000 сезонов новичков MLB Hitter
    Чему может научиться машина, глядя на сезоны новичков 1000 игроков MLB? Это то, что исследует это приложение. В этом процессе мы будем использовать неконтролируемое обучение, чтобы..

    Учебные заметки: создание моего первого пакета Node.js
    Это мои обучающие заметки, когда я научился создавать свой самый первый пакет Node.js, распространяемый через npm. Оглавление Глоссарий I. Новый пакет 1.1 советы по инициализации..

    Забудьте о Matplotlib: улучшите визуализацию данных с помощью умопомрачительных функций Seaborn!
    Примечание. Эта запись в блоге предполагает базовое знакомство с Python и концепциями анализа данных. Привет, энтузиасты данных! Добро пожаловать в мой блог, где я расскажу о невероятных..

    ИИ в аэрокосмической отрасли
    Каждый полет – это шаг вперед к великой мечте. Чтобы это происходило в их собственном темпе, необходима команда астронавтов для погони за космосом и команда технического обслуживания..


    Для любых предложений по сайту: [email protected]