重写Php访问数据库部分,如何重写我的SQL查询,以便它以特定的格式返回值(使用mysql或php)?...

我有一个叫做数字的表:

number_id | number_name

1 aaaa

2 bbbb

3 cccc

4 dddd

5 eeee

6 ffff

(它只包含6个条目)

我还有一个叫做文本的表格:

text_id | start_time | number_id | text_content

1 some date1 | 2 | blabla1

2 some date2 | 1 | blabla2

3 some date3 | 2 | blabla3

4 some date4 | 3 | blabla4

5 some date5 | 4 | blabla5

6 some date6 | 6 | blabla6

etc.

(它包含很多条目).

现在,当我正在进行这样的查询时:

SELECT

*

FROM

(SELECT

DATEDIFF(now(),

start_time) AS days_ago,

number_id,

COUNT(text_id) AS num_texts

FROM

TEXTS

WHERE

start_time BETWEEN DATE_SUB(NOW(), INTERVAL 100 DAY) AND NOW()

GROUP BY

DATE(start_time),

number_id) AS temp

它使用number_id返回每个地方过去100天每天的文本数量.结果如下:

E0Mfd.png

当我将它编码为json时,我得到:

[{"days_ago":"19","number_id":"1","num_texts":"179"},

{"days_ago":"19","number_id":"5","num_texts":"1"},

{"days_ago":"18","number_id":"1","num_texts":"61"},

{"days_ago":"18","number_id":"2","num_texts":"1"},

{"days_ago":"18","number_id":"5","num_texts":"1"},

{"days_ago":"18","number_id":"6","num_texts":"3"},

{"days_ago":"17","number_id":"3","num_texts":"1"},

{"days_ago":"8","number_id":"1","num_texts":"2"},

{"days_ago":"8","number_id":"2","num_texts":"2"},

{"days_ago":"7","number_id":"4","num_texts":"1"},

我想写一个不同的查询,或更改现有的查询.有没有办法编写一个查询,将以下列方式返回我的数据:

[{"days_ago": "7", "number_id" : "1", "num_texts" : "18", "number_id" : "2", "num_texts" : "12", "number_id" : "3", "num_texts" : "12" , ... , "number_id" : "6", "num_texts" : "1"},

{"days_ago": "6", "number_id" : "1", "num_texts" : "18", "number_id" : "2", "num_texts" : "12", "number_id" : "3", "num_texts" : "12" , ... , "number_id" : "6", "num_texts" : "1"},

{"days_ago": "5", "number_id" : "1", "num_texts" : "18", "number_id" : "2", "num_texts" : "12", "number_id" : "3", "num_texts" : "12" , ... , "number_id" : "6", "num_texts" : "1"},

{"days_ago": "4", "number_id" : "1", "num_texts" : "18", "number_id" : "2", "num_texts" : "12", "number_id" : "3", "num_texts" : "12" , ... , "number_id" : "6", "num_texts" : "1"},

{"days_ago": "3", "number_id" : "1", "num_texts" : "18", "number_id" : "2", "num_texts" : "12", "number_id" : "3", "num_texts" : "12" , ... , "number_id" : "6", "num_texts" : "1"},

{"days_ago": "2", "number_id" : "1", "num_texts" : "18", "number_id" : "2", "num_texts" : "12", "number_id" : "3", "num_texts" : "12" , ... , "number_id" : "6", "num_texts" : "1"},

{"days_ago": "1", "number_id" : "1", "num_texts" : "18", "number_id" : "2", "num_texts" : "12", "number_id" : "3", "num_texts" : "12" , ... , "number_id" : "6", "num_texts" : "1"}]

基本上每行应该有6个number_id的每一个的days_ago和值num_texts的信息.我需要限制此查询仅过去7天,所以我知道我可以在这里修改它:

BETWEEN DATE_SUB(NOW(), INTERVAL 100 DAY) AND NOW()

并将100改为7,但有可能以某种方式得到这种特定格式的其他信息吗?

哦还有一件事 – 我正在从php调用这个查询,所以如果它更容易在php中以某种方式解析它并返回作为json,这也是一个选项.

非常感谢任何提示家伙!

=========

编辑:

正如@AlexBlex指出的那样 – 我提出的json结构可能无效,因为有多次使用相同的键名.为了帮助您更好地理解我的问题 – http://thevectorlab.net/flatlab/morris.html这里是morris js图表的例子.我希望在该示例中将图表生成为名为Quarterly Apple iOS设备单元销售的图表.在水平线上我想要日期(几天前),在垂直线上我需要num_texts.我希望有6行,每行代表不同的number_id.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
提供的源码资源涵盖了安卓应用、小程序、Python应用和Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。
提供的源码资源涵盖了安卓应用、小程序、Python应用和Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值