Как возвращать значения от динамической Хранимой процедуры SQL до Платформы Объекта?

У меня есть Хранимая процедура, которая выполняет некоторый динамический SQL. Я хочу использовать эту Хранимую процедуру в платформе объекта 4, но когда я пытаюсь создать составной тип, процедура не возвращает столбцов. Есть ли какой-либо способ, которым я могу вынудить это возвратить мои значения и заставить платформу объекта получать их? Вот очень упрощенный пример того, что я хочу сделать:

CREATE PROCEDURE sp_calculatesalary(@EmployeeId as int)
begin
    declare dynsql as varachar(500)
    @dynsql='Select @Salary=Salary,@UserName=Username from employee
            where EmployeeId='+cast(@EmployeeId as varchar)+ ''
    exec(@dynsql)
    select @Salary, @UserName
end

Но это не работает. Выручите меня. В основном я хочу использовать Хранимую процедуру, чтобы выполнить динамический SQL и возвратить значения к платформе объекта.

7
задан gkrogers 2 July 2010 в 15:45
поделиться

3 ответа

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

CREATE PROCEDURE sp_calculatesalary(@EmployeeId as int)  
as 
begin   
    declare @dynsql varchar(500)   
    declare @params nvarchar(500)
    declare @salary money
    declare @username varchar(50)
    set @dynsql='Select @sal=Salary,@usernm=Username from employee where EmployeeId=@empID'   
    set @params='@empID int, @sal money OUTPUT, @usernm varchar(50) OUTPUT'
    exec sp_executesql @dynsql, @params, @empID=@EmployeeID, @sal=@salary OUTPUT, @usernm = @username OUTPUT
    SELECT @salary, @username
end
16
ответ дан 6 December 2019 в 07:50
поделиться

пробовали ли вы давать псевдонимы вашему последнему Select:

select @Salary as Salary, @UserName as UserName
0
ответ дан 6 December 2019 в 07:50
поделиться

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

0
ответ дан 6 December 2019 в 07:50
поделиться
Другие вопросы по тегам:

Похожие вопросы: