С Новым годом! Форум программистов, компьютерный форум, киберфорум
Microsoft SQL Server
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
4 / 1 / 2
Регистрация: 11.10.2009
Сообщений: 153
1

Условие в хранимой процедуре

11.11.2014, 20:25. Показов 948. Ответов 0
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Добрый день, форумчане!

Я не знаю SQL, поэтому нужна ваша помощь, помогите с добавлением условия в хранимую процедуру
Вот текст процедуры и мне необходимо проверять параметр @user_id на NULL (условие у меня уже есть вот оно:
if @user_id is null select top 1 @user_id = emp_id_buh from tccom025 where main_filial = 1) вот только не знаю куда вставить подскажите пожалуйста!

T-SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
USE db_name
GO
SET ANSI_NULLS, QUOTED_IDENTIFIER ON
GO
CREATE PROCEDURE dbo.sp_tccom010_03 
    @contragent_id int ,
    @descr nvarchar(MAX) ,
    @contact_phone nvarchar(30) ,
    @notes nvarchar(MAX) ,
    @contragent_type_id int ,
    @user_id int 
     
WITH ENCRYPTION AS BEGIN SET NOCOUNT ON exec sp_ttlog005_05 @user_id 
 
 
@error_message nvarchar(max) if not exists(select 1 from tcemp001 where tcemp001.emp_id=@user_id and tcemp001.superuser=1) and exists(select 1 from tccom025 where tccom025.contragent_id2=@contragent_id or tccom025.contragent_id=@contragent_id) begin 
set @error_message='Данного контрагента может редактировать только суперпользователь.' raiserror(@error_message,16,1) return -1 end if dbo.f_ttaad032_05(1,29,@user_id)=0 and ( exists(select contragent_id from tccom010 where contragent_id=@contragent_id and ltrim(rtrim(descr)) <> @descr) OR exists(select contragent_id from tccom010 where contragent_id=@contragent_id and contragent_type <> @contragent_type_id) ) and ( exists(select document_id_in from tffin020 where contragent_id=@contragent_id and document_closed=1) OR exists(select document_id_out from tffin030 where contragent_id=@contragent_id and document_closed=1) ) begin set @error_message='Недостаточно прав для изменения информации о контрагенте,'+char(13)+'по которому имеются закрытые документы (1,29)' raiserror(@error_message,16,1) return -1 end if exists(select 1 from tcprm001 where parametr_id=54 and _value=1) begin select @error_message='В системе уже имеется контрагент с наименованием ' + char(10) + '"' + @descr + '"' + char(10) + 'В соответствии с текущими настройками системы недопустимо создание двух контрагентов с одинаковым наименованием.' + char(10) + char(10) + 'Уже имеющийся контрагент: ID '+ CAST(min(contragent_id) as varchar) + char(10) + 'Всего подобных контрагентов: ' + cast(COUNT(1) as varchar) from tccom010 where descr=@descr and contragent_id <> @contragent_id if @error_message is not null begin raiserror(@error_message,16,1) return -1 end end update tccom010 set descr=@descr,notice=@notes,contragent_type=@contragent_type_id,phone_kontakt=@contact_phone where tccom010.contragent_id=@contragent_id return 0 END
GO
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
11.11.2014, 20:25
Ответы с готовыми решениями:

Запрос по хранимой процедуре
Здравствуйте. У меня проблема. Не получается корректно создать хранимую процедуру. В результате её...

Оператор if else в хранимой процедуре
Всем Привет! У меня ошибки в условиях, не могли бы подсказать где. Мне нужно, чтобы при...

Ошибка в хранимой процедуре
Здравствуйте! У меня при выполнении хранимой процедуры возникает следующая ошибка &quot;&quot;Ошибка...

Обращение к хранимой процедуре
У меня в хранимой процедуре объявляются переменные таблицы 2-4 штуки. (@table_without_pen,...

0
11.11.2014, 20:25
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
11.11.2014, 20:25
Помогаю со студенческими работами здесь

Проблема с курсором в хранимой процедуре
добрый день уважаемые. Нужна помощь. Написал хранимую процедуру для добавления записей в таблицу...

Успешный Update в хранимой процедуре
Создаю хранимую процедуру на обнавление. Как можно определить успешность выполнения обнавлени (т.е....

Несколько запросов в хранимой процедуре
Привет! Имею процедуру след.вида AS BEGIN IF @Num = 1 BEGIN ...

Как отключить соединения с БД в хранимой процедуре?
declare @physical_backup_device_name_var nvarchar(100) select...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
Книги и учебные ресурсы по C#
InfoMaster 08.01.2025
Базовые учебники и руководства Одной из лучших книг для начинающих является "C# 10 и . NET 6 для начинающих" Эндрю Троелсена и Филиппа Джепикса . Книга последовательно раскрывает основные концепции. . .
Что такое NullReferenceEx­­­ception и как исправить?
InfoMaster 08.01.2025
NullReferenceException - одно из самых распространенных исключений, с которым сталкиваются разработчики на C#. Это исключение возникает при попытке обратиться к членам объекта (методам, свойствам или. . .
Что такое Null Pointer Exception (NPE) и как это исправить?
InfoMaster 08.01.2025
Null Pointer Exception (NPE) - это одно из самых распространенных исключений в Java, которое возникает при попытке использовать ссылку на объект, значение которой равно null. Это исключение относится. . .
Русский язык в консоли C++
InfoMaster 08.01.2025
При разработке программ на C++ одной из частых проблем, с которой сталкиваются русскоязычные программисты, является корректное отображение кириллицы в консольных приложениях. Эта проблема особенно. . .
Telegram бот на C#
InfoMaster 08.01.2025
Разработка ботов для Telegram стала неотъемлемой частью современной экосистемы мессенджеров. C# предоставляет мощный и удобный инструментарий для создания разнообразных ботов, от простых. . .
Использование GraphQL в Go (Golang)
InfoMaster 08.01.2025
Go (Golang) является одним из наиболее популярных языков программирования, используемых для создания высокопроизводительных серверных приложений. Его архитектурные особенности и встроенные. . .
Что лучше использовать при создании класса в Java: сеттеры или конструктор?
Alexander-7 08.01.2025
Вопрос подробнее: На вопрос: «Когда одновременно создаются конструктор и сеттеры в классе – это нормально?» куратор уточнил: «Ваш класс может вообще не иметь сеттеров, а только конструктор и геттеры. . .
Как работать с GraphQL на TypeScript
InfoMaster 08.01.2025
Введение в GraphQL и TypeScript В современной разработке веб-приложений GraphQL стал мощным инструментом для создания гибких и эффективных API. В сочетании с TypeScript, эта технология. . .
Счётчик на базе сумматоров + регистров и генератора сигналов согласования.
Hrethgir 07.01.2025
Создан с целью проверки скорости асинхронной логики: ранее описанного сумматора и предополагаемых fast регистров. Регистры созданы на базе ранее описанного, предполагаемого fast триггера. То-есть. . .
Как перейти с Options API на Composition API в Vue.js
BasicMan 06.01.2025
Почему переход на Composition API актуален В мире современной веб-разработки фреймворк Vue. js продолжает эволюционировать, предлагая разработчикам все более совершенные инструменты для создания. . .
Архитектура современных процессоров
inter-admin 06.01.2025
Процессор (центральный процессор, ЦП) является основным вычислительным устройством компьютера, которое выполняет обработку данных и управляет работой всех остальных компонентов системы. Архитектура. . .
История создания реляционной модели баз данных, правила Кодда
Programming 06.01.2025
Предпосылки создания реляционной модели В конце 1960-х годов компьютерная индустрия столкнулась с серьезными проблемами в области управления данными. Существовавшие на тот момент модели данных -. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru