【问题标题】:Get data from database and build up a string to use for JSON从数据库中获取数据并构建一个用于 JSON 的字符串
【发布时间】:2017-01-26 03:11:13
【问题描述】:

我想从数据库中返回我所有的数据并建立一个字符串,或者我想循环并将结果写入 Json。

我的代码如下:

public string GetNewTickets()
{
    using (SqlConnection con = new SqlConnection(constr))
    {
        using (SqlCommand cmd = new SqlCommand("Select LoggedDate, count(ID) as ticketAmount from Tickets WHERE LoggedDate >=dateadd(day,datediff(day,0,GetDate())- 7,0) AND State = '1' group by LoggedDate"))
        {
            var ticketAmount = 0;
            var loggedDate = DateTime.Now;
            var ActualloggedDate = string.Empty;
            var convertedLoggedDate = string.Empty;

            var test = string.Empty;

            cmd.Connection = con;
            con.Open();
            var reader = cmd.ExecuteReader();

            if (reader.HasRows)
            {
                while (reader.Read())
                {
                    ticketAmount = (int)reader["ticketAmount"];
                    //Convert to JSON format
                    loggedDate = (DateTime)reader["LoggedDate"];
                    ActualloggedDate = JsonConvert.SerializeObject(loggedDate, new IsoDateTimeConverter());
                    convertedLoggedDate = ActualloggedDate.Substring(1, ActualloggedDate.Length - 4);
                }
            }
            var entity = new
            {
                ticketAmount = ticketAmount,
                loggedDate = convertedLoggedDate,
            };
            var json = serializer.Serialize(entity);
            return json;
        }
    }
}

这只会返回 json 中的一行

{"ticketAmount":1,"loggedDate":"2016-09-16T08:03:"}

我的数据库中有大约 10 条记录,我想返回所有必需的记录。结果应该是这样的

{"ticketAmount":1,"loggedDate":"2016-09-16T08:03:"}, 
{"ticketAmount":5,"loggedDate":"2016-09-17T08:03:"},
{"ticketAmount":4,"loggedDate":"2016-09-18T08:03:"}

【问题讨论】:

  • while 中添加这个var json += serializer.Serialize(entity); 并在if 之前声明var entity
  • Before if - var entity = string.Empty; in While - var json = serializer.Serialize(entity); 那么我将如何使用var entity = new { ticketAmount = ticketAmount, loggedDate = convertedLoggedDate, };
  • var json += serializer.Serialize(entity); 仔细看...它使用+= 连接字符串...所以在while 中使用它。

标签: c# json


【解决方案1】:

如果您想返回多个 JSON 对象(每行一个),您可以返回一个 JSON 数组,如下所示:

[
    {"ticketAmount":1,"loggedDate":"2016-09-16T08:03:"}, 
    {"ticketAmount":5,"loggedDate":"2016-09-17T08:03:"},
    {"ticketAmount":4,"loggedDate":"2016-09-18T08:03:"}
]

通过使用

var json = serializer.Serialize(entity);
return json;

无论存在多少匹配记录,您的程序都只序列化一个实体(最后一个)。因此,我建议将所有匹配的实体存储在 List 中并序列化 List 对象。例如:

public class EntityDto {
    public int ticketAmount {get; set;}
    public DateTime loggedDate {get; set;}
}

...

public string GetNewTickets()
{
    var entities = new List<EntityDto>();
    using (SqlConnection con = new SqlConnection(constr))
    {
        using (SqlCommand cmd = new SqlCommand("Select LoggedDate, count(ID) as ticketAmount from Tickets WHERE LoggedDate >=dateadd(day,datediff(day,0,GetDate())- 7,0) AND State = '1' group by LoggedDate"))
        {
            var ticketAmount = 0;
            var loggedDate = DateTime.Now;
            var ActualloggedDate = string.Empty;
            var convertedLoggedDate = string.Empty;

            var test = string.Empty;

            cmd.Connection = con;
            con.Open();
            var reader = cmd.ExecuteReader();

            if (reader.HasRows)
            {
                while (reader.Read())
                {
                    ticketAmount = (int)reader["ticketAmount"];
                    //Convert to JSON format
                    loggedDate = (DateTime)reader["LoggedDate"];
                    ActualloggedDate = JsonConvert.SerializeObject(loggedDate, new IsoDateTimeConverter());
                    convertedLoggedDate = ActualloggedDate.Substring(1, ActualloggedDate.Length - 4);
                    var entity = new EntityDto
                     {
                         ticketAmount = ticketAmount,
                         loggedDate = convertedLoggedDate,
                     };
                    entites.Add(entity);
                }
            }

        }            
    }
    var json = serializer.Serialize(entities);
    return json;
}

【讨论】:

  • 无法编辑帖子,但我将代码更改为 public string loggedDate {get; set;} 也查看 var var entites = new List&lt;EntityDto&gt;(); 并将其更改为 entities,谢谢
猜你喜欢
  • 1970-01-01
  • 2012-11-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2018-11-16
  • 1970-01-01
  • 2016-04-03
  • 1970-01-01
相关资源
最近更新 更多