[英]Create specific json response from linq to SQL query output?
I am working on Web API.我正在研究 Web API。 I am getting data from one database table:
我从一个数据库表中获取数据:
DispatchData dta = new DispatchData();
using (SalesDataContext oSqlData4 = new SalesDataContext())
{
var result = (from x in oSqlData4.Finances
where (x.records.ID.Equals("12") ||
x.records.ID.Equals("123"))
where (x.Status == "Not Approved")
select x).ToList();
foreach (var item in result)
{
dta.data = new string[] { item.Order_ID.ToString(), item.ID.ToString() };
}
var json = JsonConvert.SerializeObject(dta);
return json;
}
public class DispatchData
{
public string[] data;
}
This code is returning only one record:此代码仅返回一条记录:
{ "data": ["2508", "4684"] }
I want each row in array like this我希望数组中的每一行都像这样
{"data":[ ["2508","4684"],["2223","1123"],....] }
Why not make return the result
as strongly typed Model of List<DispatchData>
:为什么不将
result
作为List<DispatchData>
强类型模型返回:
Your DispatchData
class:您的
DispatchData
类:
public class DispatchData
{
public string Order_ID {get;set;}
public string ID {get;set;}
}
You can create a Root
class to handle your JSON
:您可以创建一个
Root
类来处理您的JSON
:
public class Root
{
public List<DispatchData> data=new List<DispatchData>();
}
And you can return from your query like this:您可以像这样从查询中返回:
Root dta = new Root();
using (SalesDataContext oSqlData4 = new SalesDataContext())
{
dta.data = (from x in oSqlData4.Finances
where (x.records.ID.Equals("12") ||
x.records.ID.Equals("123"))
where (x.Status == "Not Approved")
select x).ToList();
var json = JsonConvert.SerializeObject(dta);
return json;
}
For the result you want, your class is defined wrongly对于你想要的结果,你的类定义错误
public class DispatchData
{
public string[][] data;
}
Then you can directly select the pair of IDs in an array, then nest them in another array, and assign it directly to dta.data
然后就可以直接选择一个数组中的一对ID,然后再嵌套到另一个数组中,直接赋值给
dta.data
using (SalesDataContext oSqlData4 = new SalesDataContext())
{
var dta = new DispatchData() {
data = (from x in oSqlData4.Finances
where (x.records.ID.Equals("12") ||
x.records.ID.Equals("123"))
where (x.Status == "Not Approved")
select new[]{ x.Order_ID.ToString(), item.ID.ToString() }
).ToArray()
};
var json = JsonConvert.SerializeObject(dta);
return json;
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.