首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >ASP.NET核心存储过程错误: InvalidCastException

ASP.NET核心存储过程错误: InvalidCastException
EN

Stack Overflow用户
提问于 2021-02-11 14:30:26
回答 1查看 55关注 0票数 0

好的一天,我有这个存储过程,因为查询的递归,如果我把这个放到LINQ风格的代码或过程中,它可能会导致性能问题。

所以我有这个存储过程

代码语言:javascript
运行
复制
CREATE PROCEDURE GetReferralTree @parentID nvarchar(450)
AS

WITH referral_CTE (Id, Fullname, Referral)AS  
(  
   SELECT dbo.AspNetUsers.Id,dbo.AspNetUsers.Fullname, dbo.AspNetUsers.Referral from AspNetUsers  where Id = @parentID
   union all
   SELECT AspNetUsers.Id, AspNetUsers.Fullname, AspNetUsers.Referral
   from AspNetUsers   
   JOIN referral_CTE ON AspNetUsers.Referral = referral_CTE.id
)  
SELECT distinct * FROM referral_CTE 

GO;

我在我的asp.net核心web应用程序上调用了它

代码语言:javascript
运行
复制
[HttpGet]
    public ActionResult GetReferralTree(string id)
    {
        List<ReferralTreeViewModel> hierarchy = new List<ReferralTreeViewModel>();
        var parentIDParam = new SqlParameter("@parentID", id);
        hierarchy = (List<ReferralTreeViewModel>)_context.AspNetUsers.FromSqlRaw("exec GetReferralTree @parentID ", parentIDParam)
            .Select(x => new ReferralTreeViewModel()
            {
                Id = x.Id,
                Fullname = x.Fullname,
                ParentId = x.Referral
            })
            .AsEnumerable() ;
        return Ok(hierarchy);
    }

,但返回的内容如下

代码语言:javascript
运行
复制
    System.InvalidCastException: Unable to cast object of type 'Microsoft.EntityFrameworkCore.Query.Internal.EntityQueryable`1[Genea.Areas.Admin.Models.ReferralTreeViewModel]' to type 'System.Collections.Generic.List`1[Genea.Areas.Admin.Models.ReferralTreeViewModel]'.
   at Genea.Areas.Admin.Controllers.GenealogyController.GetReferralTree(String id) in C:\Users\winshiero\source\repos\Genea\Areas\Admin\Controllers\GenealogyController.cs:line 43
   at lambda_method(Closure , Object , Object[] )
   at Microsoft.Extensions.Internal.ObjectMethodExecutor.Execute(Object target, Object[] parameters)
   at Microsoft.AspNetCore.Mvc.Infrastructure.ActionMethodExecutor.SyncActionResultExecutor.Execute(IActionResultTypeMapper mapper, ObjectMethodExecutor executor, Object controller, Object[] arguments)
   at Microsoft.AspNetCore.Mvc.Infrastructure.ControllerActionInvoker.InvokeActionMethodAsync()
   at Microsoft.AspNetCore.Mvc.Infrastructure.ControllerActionInvoker.Next(State& next, Scope& scope, Object& state, Boolean& isCompleted)
   at Microsoft.AspNetCore.Mvc.Infrastructure.ControllerActionInvoker.InvokeNextActionFilterAsync()
--- End of stack trace from previous location where exception was thrown ---
   at Microsoft.AspNetCore.Mvc.Infrastructure.ControllerActionInvoker.Rethrow(ActionExecutedContextSealed context)
   at Microsoft.AspNetCore.Mvc.Infrastructure.ControllerActionInvoker.Next(State& next, Scope& scope, Object& state, Boolean& isCompleted)
   at Microsoft.AspNetCore.Mvc.Infrastructure.ControllerActionInvoker.InvokeInnerFilterAsync()
--- End of stack trace from previous location where exception was thrown ---
   at Microsoft.AspNetCore.Mvc.Infrastructure.ResourceInvoker.<InvokeNextResourceFilter>g__Awaited|24_0(ResourceInvoker invoker, Task lastTask, State next, Scope scope, Object state, Boolean isCompleted)
   at Microsoft.AspNetCore.Mvc.Infrastructure.ResourceInvoker.Rethrow(ResourceExecutedContextSealed context)
   at Microsoft.AspNetCore.Mvc.Infrastructure.ResourceInvoker.Next(State& next, Scope& scope, Object& state, Boolean& isCompleted)
   at Microsoft.AspNetCore.Mvc.Infrastructure.ResourceInvoker.InvokeFilterPipelineAsync()
--- End of stack trace from previous location where exception was thrown ---
   at Microsoft.AspNetCore.Mvc.Infrastructure.ResourceInvoker.<InvokeAsync>g__Awaited|17_0(ResourceInvoker invoker, Task task, IDisposable scope)
   at Microsoft.AspNetCore.Routing.EndpointMiddleware.<Invoke>g__AwaitRequestTask|6_0(Endpoint endpoint, Task requestTask, ILogger logger)
   at AspNetCoreHero.ToastNotification.Middlewares.NotyfMiddleware.InvokeAsync(HttpContext context, RequestDelegate next)
   at Microsoft.AspNetCore.Builder.UseMiddlewareExtensions.<>c__DisplayClass5_1.<<UseMiddlewareInterface>b__1>d.MoveNext()
--- End of stack trace from previous location where exception was thrown ---
   at Microsoft.AspNetCore.Authorization.AuthorizationMiddleware.Invoke(HttpContext context)
   at Microsoft.AspNetCore.Authentication.AuthenticationMiddleware.Invoke(HttpContext context)
   at Microsoft.AspNetCore.Diagnostics.EntityFrameworkCore.MigrationsEndPointMiddleware.Invoke(HttpContext context)
   at Microsoft.AspNetCore.Diagnostics.EntityFrameworkCore.DatabaseErrorPageMiddleware.Invoke(HttpContext httpContext)
   at Microsoft.AspNetCore.Diagnostics.EntityFrameworkCore.DatabaseErrorPageMiddleware.Invoke(HttpContext httpContext)
   at Microsoft.AspNetCore.Diagnostics.DeveloperExceptionPageMiddleware.Invoke(HttpContext context)
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-02-11 22:54:31

尝试使用以下命令:

代码语言:javascript
运行
复制
    [HttpGet]
    public ActionResult<List<ReferralTreeViewModel>> GetReferralTree(string id)
    {
            var parentIDParam = new SqlParameter("@parentID", id);
       var  hierarchy = _context.AspNetUsers.FromSqlRaw("exec GetReferralTree @parentID ", 
          parentIDParam).ToArray();
          var result  hierarchy.Select(x => new ReferralTreeViewModel
            {
                Id = x.Id,
                Fullname = x.Fullname,
                ParentId = x.Referral
            }).ToList();
           
        return Ok(result);
    }
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/66149788

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档