Как выполнить хранимую процедуру SQL Server в SQL Developer? - PullRequest
135 голосов
/ 09 ноября 2010

Я получил учетную запись пользователя для базы данных SQL Server, которая имеет только привилегии для выполнения хранимой процедуры. Я добавил JAR-файл JTDS JTDS для SQL Server в SQL Developer и добавил его в качестве стороннего драйвера JDBC. Я могу успешно войти в базу данных SQL Server. Мне дали этот синтаксис для запуска процедуры:

EXEC proc_name 'paramValue1' 'paramValue2'

Когда я запускаю это как оператор или сценарий, я получаю эту ошибку:

Error starting at line 1 in command:
EXEC proc_name 'paramValue1' 'paramValue2'
Error report:
Incorrect syntax near the keyword 'BEGIN'.

Я попытался обернуть оператор в BEGIN/END, но получил ту же ошибку. Можно ли вызвать процедуру из SQL Developer? Если да, какой синтаксис мне нужно использовать?

Ответы [ 9 ]

212 голосов
/ 21 сентября 2012

Вам не нужно предложение EXEC. Просто используйте

proc_name paramValue1, paramValue2

(и вам нужны запятые, как упоминал Мисномер)

67 голосов
/ 09 ноября 2010

Вы пропали без вести ,

EXEC proc_name 'paramValue1','paramValue2'
17 голосов
/ 12 июля 2013

Вам нужно сделать это:

    exec procName 
    @parameter_1_Name = 'parameter_1_Value', 
    @parameter_2_name = 'parameter_2_value',
    @parameter_z_name = 'parameter_z_value'
4 голосов
/ 30 марта 2015
    EXECUTE [or EXEC] procedure_name
  @parameter_1_Name = 'parameter_1_Value', 
    @parameter_2_name = 'parameter_2_value',
    @parameter_z_name = 'parameter_z_value'
0 голосов
/ 21 мая 2018

Я знаю, что это старый.Но это может помочь другим.

Я добавил функцию вызова SP между BEGIN / END.Вот рабочий скрипт.

ALTER Proc [dbo].[DepartmentAddOrEdit]
@Id int,
@Code varchar(100),
@Name varchar(100),
@IsActive bit ,
@LocationId int,
@CreatedBy int,
@UpdatedBy int
AS
    IF(@Id = 0)

    BEGIN
    INSERT INTO Department (Code,Name,IsActive,LocationId,CreatedBy,UpdatedBy,CreatedAt)
        VALUES(@Code,@Name,@IsActive,@LocationId,@CreatedBy,@UpdatedBy,CURRENT_TIMESTAMP)

    EXEC dbo.LogAdd @CreatedBy,'DEPARTMENT',@Name
    END

    ELSE

    UPDATE Department SET
        Code = @Code,
        Name = @Name,
        IsActive = @IsActive,
        LocationId = @LocationId,
        CreatedBy = @CreatedBy,
        UpdatedBy = @UpdatedBy,
        UpdatedAt =  CURRENT_TIMESTAMP 
    where Id = @Id 
0 голосов
/ 07 ноября 2016
EXEC proc_name @paramValue1 = 0, @paramValue2 = 'some text';
GO

Если целью хранимой процедуры является выполнение INSERT для таблицы, в которой объявлено поле Identity, то поле в этом сценарии @paramValue1 должно быть объявлено и просто передать значение 0, посколькуэто будет автоинкремент.

0 голосов
/ 08 апреля 2015

Если вам просто нужно извинить хранимую процедуру proc_name 'paramValue1' , 'paramValue2'..., в то же время вы выполняете более одного запроса, например, один запрос на выборку и хранимую процедуру, вы должны добавить select * from tableName EXEC proc_name paramValue1 , paramValue2...

0 голосов
/ 17 декабря 2013
Select * from Table name ..i.e(are you save table name in sql(TEST) k.

Select * from TEST then you will execute your project.
0 голосов
/ 09 июля 2013

Хранимые процедуры можно запускать в средстве разработки SQL, используя следующий синтаксис

BEGIN имя_процесса ();END;

Если есть какие-либо параметры, то они должны быть переданы.

...