简体   繁体   English

创建从 linq 到 SQL 查询输出的特定 json 响应?

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM