Nano Hash - криптовалюты, майнинг, программирование

Оператор IF ELSE в предложении WHERE SQL

Я хочу добиться от sql следующего: предположим, у меня есть @accountId int в качестве параметра в хранимой процедуре, теперь, если я передаю параметр как 99999, то во всех операторах выбора он выбирает WHERE AccountId <> 124, в противном случае, если я передаю любой другой параметр, он выбирает WHERE AccountId=@accountId. Этот оператор является частью очень длинной хранимой процедуры, поэтому я не включил всю процедуру.

WHERE (IF(AccountId = 99999) 
       BEGIN
          AccountId <> 124
       END
       ELSE
       BEGIN
          AccountId = @accountId
       END)

ИЛИ Могу ли я добиться аналогичного результата из заявления CASE. Что-то типа,

WHERE (AccountId(CASE(AccountId) WHEN 99999 THEN <>124 ELSE =@accountId))

Я отредактировал свой вопрос, прошу прощения за то, что задал его несвязанным образом. Пожалуйста, дайте мне знать, если это имеет смысл для вас или вам нужна дополнительная информация.

24.05.2015

  • Возможно, вы захотите использовать NULL вместо магического числа, чтобы указать, что вы не хотите фильтровать по AccountId: where ( @AccountId is NULL and AccountId <> 124 ) or ( @AccountId is not NULL and AccountId = @AccountId ). 24.05.2015

Ответы:


1

Синтаксис «один или все», который я обычно использую, выглядит следующим образом: (с -1 для всех я бы не стал использовать какое-либо теоретически возможное положительное число.)

WHERE
    @AccountId IN (AccountID, -1)

и чтобы добавить ваше дополнительное условие, это должно работать:

WHERE
    @AccountId IN (AccountID, -1)
    AND AccountID <> IIF(@AccountID = -1, 124, -1)
24.05.2015
Новые материалы

Кластеризация: более глубокий взгляд
Кластеризация — это метод обучения без учителя, в котором мы пытаемся найти группы в наборе данных на основе некоторых известных или неизвестных свойств, которые могут существовать. Независимо от..

Как написать эффективное резюме
Предложения по дизайну и макету, чтобы представить себя профессионально Вам не позвонили на собеседование после того, как вы несколько раз подали заявку на работу своей мечты? У вас может..

Частный метод Python: улучшение инкапсуляции и безопасности
Введение Python — универсальный и мощный язык программирования, известный своей простотой и удобством использования. Одной из ключевых особенностей, отличающих Python от других языков, является..

Как я автоматизирую тестирование с помощью Jest
Шутка для победы, когда дело касается автоматизации тестирования Одной очень важной частью разработки программного обеспечения является автоматизация тестирования, поскольку она создает..

Работа с векторными символическими архитектурами, часть 4 (искусственный интеллект)
Hyperseed: неконтролируемое обучение с векторными символическими архитектурами (arXiv) Автор: Евгений Осипов , Сачин Кахавала , Диланта Хапутантри , Тимал Кемпития , Дасвин Де Сильва ,..

Понимание расстояния Вассерштейна: мощная метрика в машинном обучении
В обширной области машинного обучения часто возникает необходимость сравнивать и измерять различия между распределениями вероятностей. Традиционные метрики расстояния, такие как евклидово..

Обеспечение масштабируемости LLM: облачный анализ с помощью AWS Fargate и Copilot
В динамичной области искусственного интеллекта все большее распространение получают модели больших языков (LLM). Они жизненно важны для различных приложений, таких как интеллектуальные..