Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/csharp/306.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/5/sql/74.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C# 将用户定义的函数转换为EF的存储过程_C#_Sql_Sql Server_Entity Framework - Fatal编程技术网

C# 将用户定义的函数转换为EF的存储过程

C# 将用户定义的函数转换为EF的存储过程,c#,sql,sql-server,entity-framework,C#,Sql,Sql Server,Entity Framework,这是我在项目中使用的用户定义函数: CREATE FUNCTION [dbo].[Encrypt] ( @Password nvarchar(4000) ) RETURNS varbinary(4000) AS BEGIN SELECT @Password = CONVERT(nvarchar(4000),@Password); RETURN HashBytes('SHA1', @Password); END GO 我需要实体框架,这样就可以在SQL Server 2012 Express的存

这是我在项目中使用的用户定义函数:

CREATE FUNCTION [dbo].[Encrypt]
(
@Password nvarchar(4000)
)
RETURNS varbinary(4000)
AS
BEGIN
SELECT @Password = CONVERT(nvarchar(4000),@Password);
RETURN HashBytes('SHA1', @Password);
END
GO

我需要实体框架,这样就可以在SQL Server 2012 Express的存储过程中找到转换此框架的方法了?

过程定义

CREATE PROCEDURE [dbo].[usp_Encrypt]
@Password   nvarchar(4000), 
@HashedPass varbinary(4000) OUTPUT
AS
BEGIN
 SET NOCOUNT ON;
   SET @HashedPass = HashBytes('SHA1',CONVERT(nvarchar(4000),@Password));
END
执行程序

DECLARE @RtnHashedPass varbinary(4000);

EXECUTE [dbo].[usp_Encrypt]
@Password   = 'myPassword'
@HashedPass = @RtnHashedPass OUTPUT

SELECT @RtnHashedPass  --<-- Do what ever you want to do with this value
DECLARE@RtnHashedPass varbinary(4000);
执行[dbo].[usp\U加密]
@密码='myPassword'
@HashedPass=@RtnHashedPass输出

选择@RtnHashedPass——好的。我已经使用您的过程定义创建了存储过程,对吗?那么,我如何执行这个过程呢?是的,如果你阅读了我答案中的第二部分,这是正确的。我已经解释了如何执行这个过程。只有一个问题。原始函数返回varbinary,但新函数返回nvarchar。这是不是一个错误?因为在我的旧数据库中,密码值是varbinary。