thinkphp5连表查询,max(),GROUP_CONCAT(),concat_ws(),CONCAT(),group by综合运用方法及字符串拼接、拆分数组重组

本文介绍了在ThinkPHP5中使用MySQL进行连表查询,结合max(), GROUP_CONCAT(), CONCAT()等函数处理数据的方法。作者通过三种策略讨论如何获取和重组数据,并提醒读者注意group_concat()函数的长度限制问题及其解决方案。" 53574730,4432795,HTTP协议详解:从零开始学写HTTP服务器,"['http协议', '网络编程', '服务器开发']
摘要由CSDN通过智能技术生成

文末有BUG提示

总结:
关于2两个关联表聚合查询返回数据个人总结。
数据请求用到max(),GROUP_CONCAT(),concat_ws(),CONCAT(),group by。
php字符串拆分用到explode()。
php将两个索引数组重组成关联数组用到array_combine()。
我这个需求和做法,纯属个人根据自己的想法和需求来的,本人不是专业程序员,自学的,目前自己还没有找到更好的方法,这里纯属个人记录,如果还有其他好用的方法,还望大家给与指点。

一、返回数据结构:

下面为接口返回的数据结构,数据来自2张表,分别为project和project_combo。
下面的数据是采用第三种方法得到的数据

"data":[
	{
   
	"id": 5,
	"group_name": "年卡",
	"type": "times",
	"sort": null,
	"tags": null,
	"is_show": "Y",
	"summary": null,
	"group_combo": [
			{
   
				"id": "7",
				"pid": "5",
				"title": "年卡*1年",
				"simple_title": "1年",
				"group_price": "2280.00",
				"price": "2280.00",
				"num": "-1",
				"days": "365",
				"unit": "day"
			},
			{
   
				"id": "8",
				"pid": "5",
				"title": "年*2年",
				"simple_title": "2年",
				"group_price": "3680.00",
				"price": "3680.00",
				"num": "-1",
				"days": "2",
				"unit": "year"
			}
		]
	},
	{
   
			"id": 7,
			"group_name": "月卡",
			"type": "times",
			"sort": null,
			"tags": null,
			"is_show": "Y",
			"summary": null,
			"group_combo": [
				{
   
					
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
GROUP_CONCAT函数是MySQL中的一个聚合函数,用于将多行数据按照指定的分隔符连接成一个字符串。在TP框架中,可以使用Db类的query方法来执行原生的SQL语句,从而使用GROUP_CONCAT函数。 例如,你可以使用以下代码来使用GROUP_CONCAT函数: ```php $data = Db::query("SELECT t.measure_id, t.link_name, GROUP_CONCAT(t.range_time SEPARATOR ',') AS range_time FROM tb_assessment_criteria t GROUP BY t.measure_id"); ``` 这个例子中,我们使用了原生的SQL语句来执行查询操作,将结果存储在$data变量中。在SELECT语句中,我们使用了GROUP_CONCAT函数将t.range_time字段按照逗号分隔符连接成一个字符串,并起了一个别名range_time。然后,我们使用GROUP BY子句将结果按照t.measure_id进行分组。 希望这个例子能够帮助你理解如何在TP框架中使用GROUP_CONCAT函数。如果你有任何其他问题,请随时提问。 #### 引用[.reference_title] - *1* *3* [thinkphp中使用group_concat()函数时的排序方法](https://blog.csdn.net/weixin_44585369/article/details/122945639)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [认识group_concat](https://blog.csdn.net/m0_52796363/article/details/120831087)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值