我正在尝试返回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查询
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;
我做错了什么?希望有人可以帮助我。谢谢!
答案 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
您错过了案例表达式总和的别名,您可以尝试运行原始查询,并查看结果集是否具有您希望确保的列名称。