当前位置: 首页 > news >正文

thinkphp6入门(25)-- 分组查询 GROUP_CONCAT

假设表名为 user_courses,字段为 user_id 和 course_name,存储每个用户选修的课程,想查询每个学生选修的所有课程

图片

SQL 原生查询

SELECT user_id, GROUP_CONCAT(course_name) as courses FROM user_courses GROUP BY user_id;
ThinkPHP 代码实现

在 ThinkPHP 中,你可以使用查询构造器来实现类似的功能:


use think\facade\Db;// 查询每个用户选修的所有课程
$data = Db::name('user_courses')->field('user_id, GROUP_CONCAT(course_name) as courses') // 使用 GROUP_CONCAT 函数将课程合并->group('user_id') // 按 user_id 分组->select();// 输出结果
print_r($data);

解释:

  1. field('user_id, GROUP_CONCAT(course_name) as courses'):选择 user_id 和使用 GROUP_CONCAT 函数将 course_name 字段中该用户的所有课程组合成一个字符串,并命名为 courses

  2. group('user_id'):按 user_id 进行分组,确保每个用户只会有一行结果,并且课程会聚合到这一行中。

也可以使用模型查询

UserCourse.php

<?php
namespace app\model;use think\Model;class UserCourse extends Model
{// 设置当前模型对应的完整数据表名称protected $name = 'user_courses'; // 表名
}

use app\model\UserCourse;$data = UserCourse::field('user_id, GROUP_CONCAT(course_name) as courses')  // 聚合查询->group('user_id')  // 按用户分组->select();// 输出查询结果
print_r($data);

查询结果

返回的数据格式类似如下:

每个用户的 courses 字段是该用户选修的所有课程的组合,多个课程以逗号分隔。


[['user_id' => 1, 'courses' => 'Math,English,History'],['user_id' => 2, 'courses' => 'Physics,Chemistry'],['user_id' => 3, 'courses' => 'Biology,Geography,Math']
]

扩展:

如果你想按字母顺序排列每个用户的课程,可以在 GROUP_CONCAT 中使用 ORDER BY 进行排序:

use think\facade\Db;$data = Db::name('user_courses')->field('user_id, GROUP_CONCAT(course_name ORDER BY course_name ASC) as courses')->group('user_id')->select();print_r($data);

如果结果想以user_id为key

<?php
namespace app\controller;use app\BaseController;
use app\model\UserCourse;class Course extends BaseController
{public function index()
{// 查询每个用户选修的所有课程$data = UserCourse::field('user_id, GROUP_CONCAT(course_name) as courses')->group('user_id')->select()->toArray();// 使用 array_column 将 user_id 作为键$data = array_column($data, null, 'user_id');// 返回 JSON 数据return json($data);}
}

结果


[1 => ['user_id' => 1, 'courses' => 'Math,English,History'],2 => ['user_id' => 2, 'courses' => 'Physics,Chemistry'],3 => ['user_id' => 3, 'courses' => 'Biology,Geography,Math'],
]

如果想将字符串转为数组

// 将 courses 字段的字符串转换为数组
foreach ($data as &$item) {$item['courses'] = explode(',', $item['courses']);
}

by 软件工程小施同学

http://www.lryc.cn/news/455668.html

相关文章:

  • 小米 MIX FOLD工程固件 更换字库修复分区 资源预览与刷写说明
  • Flutter全局统一自定义导航栏返回按钮
  • 微信图片的超能力:5大隐秘功能揭秘,让你成为信息处理大师
  • python实现RC4加解密算法
  • BLE MESH学习2——自定义MESH网络架构思考
  • 路由器的工作机制
  • Studying-多线程学习Part3 - condition_variable与其使用场景、C++11实现跨平台线程池
  • 开发自定义starter
  • Vue2电商平台(五)、加入购物车,购物车页面
  • 众数信科 AI智能体政务服务解决方案——寻知智能笔录系统
  • Redis篇(面试题 - 连环16炮)(持续更新迭代)
  • selenium元素定位
  • 美畅物联丨视频汇聚从“设”开始:海康威视摄像机设置详解
  • 聊天机器人羲和的代码04
  • Linux安装配置Jupyter Lab并开机自启
  • Java基础——`UUID.randomUUID()` 方法详细介绍
  • 前端面试常见手写代码题【详细篇】
  • 当代最厉害的哲学家改名大师颜廷利:北京、上海、广州和深圳房价精准预测
  • MySQL常用指令码
  • OpenHarmony(鸿蒙南向开发)——轻量系统内核(LiteOS-M)【扩展组件】
  • 官方ROM 免费下载! 王者归来! 华为秘盒media Q M310(续)
  • 【Docker】05-Docker部署前端项目
  • SQL进阶技巧:如何优化NULL值引发的数据倾斜问题?
  • 【09】纯血鸿蒙HarmonyOS NEXT星河版开发0基础学习笔记-Class类基础全解(属性、方法、继承复用、判断)
  • 快速提升波段交易技能:4种实用策略分享
  • LeetCode 11 Container with Most Water 解题思路和python代码
  • 【深度学习】损失函数
  • 力扣 中等 46.全排列
  • LabVIEW机床加工监控系统
  • 第五届智能设计国际会议(ICID 2024)