У меня есть Хранимая процедура, которая выполняет некоторый динамический 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 и возвратить значения к платформе объекта.
Возможно, вы могли бы рассмотреть параметризованный 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
пробовали ли вы давать псевдонимы вашему последнему Select:
select @Salary as Salary, @UserName as UserName
Что ж, если EF не может распознать, что должна вернуть ваша хранимая процедура, тогда заранее создайте сложный тип. Вы можете создать сложный тип, щелкнув правой кнопкой мыши в любом месте модели и добавив сложный тип. Затем, когда вы импортируете свою хранимую процедуру, вы можете выбрать сложный тип из раскрывающегося списка.