Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/csharp/309.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# 如何在ActionResult实体框架Web API中调用存储过程?_C#_Entity Framework_Asp.net Web Api - Fatal编程技术网

C# 如何在ActionResult实体框架Web API中调用存储过程?

C# 如何在ActionResult实体框架Web API中调用存储过程?,c#,entity-framework,asp.net-web-api,C#,Entity Framework,Asp.net Web Api,我试图执行ActionResult中的存储过程,以json格式返回它。我的存储过程名称是db.SpCategoriesRead,我需要传递这些参数:(“1.1”,0,0,”) 我是实体框架的新手,我使用直接命令完成了它,但我用存储过程替换了它,它不起作用 这是我的密码: public ActionResult cats() { bool isValid = false; string authToken = ""; if (Request["dt

我试图执行
ActionResult
中的存储过程,以json格式返回它。我的存储过程名称是
db.SpCategoriesRead
,我需要传递这些参数:(“1.1”,0,0,”)

我是实体框架的新手,我使用直接命令完成了它,但我用存储过程替换了它,它不起作用

这是我的密码:

public ActionResult cats()
{
        bool isValid = false;
        string authToken = "";

        if (Request["dt"] != null)
            authToken = Request["dt"].ToString().Trim();
        else
            return Content("{\"error\":\"Please send device token parameter 'dt'.\"}", "application/json");

        string message = (new CommonFunction()).ValidateToken(authToken, out isValid);

        if (isValid)
        {
            var q = db.SpCategoriesRead("1.1", 0, 0, "");

            //----------------------------------------------------------------------------------------------------------------------------------------
            //var q = db.Categories.Where(p => !p.ParentCategoryID.HasValue && p.StatusID.Equals(1));
            if (q.Count() < 1)
                return Content("{\"error\":\"No results found.\"}", "application/json");

            return Json(q.OrderBy(cat => cat.SortOrder).Select(c => new { c.CategoryID, c.CatName, c.IconFile, LogoFile = string.Concat("white-", c.LogoFile) }).ToList(), JsonRequestBehavior.AllowGet);
        }
        else
        {
            return Content("{\"error\":\"" + message + "\"}", "application/json");
        }
}
public ActionResult猫()
{
bool isValid=false;
字符串authToken=“”;
如果(请求[“dt”]!=null)
authToken=Request[“dt”].ToString().Trim();
其他的
返回内容(“{\”error\”:\“请发送设备令牌参数'dt.\”}”,“应用程序/json”);
字符串消息=(new CommonFunction()).ValidateToken(authToken,out isValid);
如果(有效)
{
var q=db.SpCategoriesRead(“1.1”,0,0,”);
//----------------------------------------------------------------------------------------------------------------------------------------
//var q=db.Categories.Where(p=>!p.ParentCategoryID.HasValue&&p.StatusID.Equals(1));
if(q.Count()<1)
返回内容(“{\”错误\“:\”未找到任何结果。\“}”,“应用程序/json”);
返回Json(q.OrderBy(cat=>cat.SortOrder).Select(c=>new{c.CategoryID,c.CatName,c.IconFile,LogoFile=string.Concat(“white-”,c.LogoFile)}.ToList(),JsonRequestBehavior.AllowGet);
}
其他的
{
返回内容(“{\”error\”:\”+message+“\”}”,“application/json”);
}
}

什么不起作用?如果(q.Count()<1)System.InvalidCastException:指定的强制转换无效,它将在此处停止。仅供参考:不要返回JSON,只返回响应类的实例。序列化(JSON、XML)由ASP.NET本身完成