System.ArgumentException:Column' COLUMN_NAME'不属于表

时间:2016-07-15 09:42:17

标签: sql-server asp.net-mvc chart.js jsonresult

我正在尝试返回SP结果,使用JSon方法,就像在本教程http://prashantjayle.blogspot.com/2015/05/chartjs-with-aspnet-mvc-5.html中一样,但是当我运行它时,我需要的图表不会显示在视图上。

在我的控制器中,我有这段代码:

 public JsonResult GetData()
    {
        DataTable dtTable = new DataTable();
        List<string> lstSales = new List<string>();
        List<string> lstProduct = new List<string>();


        string strQuery = "SP_SALES_PER_PRODUCT";

        SqlConnection con = new SqlConnection (ConfigurationManager.ConnectionStrings["ebms_connection"].ToString());
        SqlCommand cmd = new SqlCommand(strQuery, con);
        cmd.CommandType = CommandType.StoredProcedure;
        SqlDataAdapter da = new SqlDataAdapter(cmd);
        da.Fill(dtTable);


        foreach(DataRow row in dtTable.Rows)
        {
            lstSales.Add(row["TOTAL_AMT_PER_ITEM"].ToString());
            lstProduct.Add(row["PRODUCT_CODE"].ToString()); 
        }


        var BarChart = new
        {

            SALES = lstSales,
            PRODUCTS = lstProduct
        };
        return Json (BarChart, JsonRequestBehavior.AllowGet);
    }

错误指向这行代码:

lstSales.Add(row["TOTAL_AMT_PER_ITEM"].ToString());

TOTAL_AMT_PER ITEM是我在SP中调用的列。 这是我的SP查询

&#13;
&#13;
SELECT p.PRODUCT_CODE, SUM(case when p.PRODUCT_ID=od.PRODUCT_ID and od.ORDER_ID=o.ORDER_ID then od.TOTAL_AMT_PER_ITEM else 0 end)
FROM [ORDER] o
INNER JOIN ORDER_DETAILS od
ON o.ORDER_ID = od.ORDER_ID
INNER JOIN PRODUCT p
ON od.PRODUCT_ID=p.PRODUCT_ID
GROUP BY p.PRODUCT_CODE
&#13;
&#13;
&#13;

我做错了什么?希望有人可以帮助我。谢谢!

1 个答案:

答案 0 :(得分:1)

尝试以下查询

SELECT p.PRODUCT_CODE, SUM(case when p.PRODUCT_ID=od.PRODUCT_ID and    od.ORDER_ID=o.ORDER_ID then od.TOTAL_AMT_PER_ITEM else 0 end) 
as TOTAL_AMT_PER_ITEM
FROM [ORDER] o
INNER JOIN ORDER_DETAILS od
ON o.ORDER_ID = od.ORDER_ID
INNER JOIN PRODUCT p
ON od.PRODUCT_ID=p.PRODUCT_ID
GROUP BY p.PRODUCT_CODE

您错过了案例表达式总和的别名,您可以尝试运行原始查询,并查看结果集是否具有您希望确保的列名称。