Entity Framework Code-First Execute Scalar-Valued Functions

前端 未结 1 1219
独厮守ぢ
独厮守ぢ 2020-12-06 10:25

How can I execute a scalar function using code first? Below is what I have tried but only the query itself is being returned, not the return value.

using (v         


        
相关标签:
1条回答
  • 2020-12-06 10:45

    SqlQuery returns an instance of DbRawSqlQuery. This class is an enumerable and it expects you to enumerate it via either the standard LINQ operators, or via foreach, etc. .ToString() on this object simply returns the query that will be executed. To get the result you want, use .Single() or .SingleAsync().

    queryResult = dbContext.Database
        .SqlQuery<string>("SELECT [dbo].[ufnGetTotalUsers] (GETDATE())")
        .Single();
    

    This should return the scalar string result you are looking for.

    That being said, your query looks like invalid SQL. Are you just trying to just get the date from SQL Server? If so, the query should probably be SELECT GETDATE(). Once you do that, you might have to use .SqlQuery<DateTime>() since the type of that value is not a string.

    0 讨论(0)
提交回复
热议问题