Mysql 中一对多查询字符串拼接问题

现数据库中有两张表:

order_info-订单信息表

CREATE TABLE `order_info` (
  `order_id` varchar(32) NOT NULL COMMENT '订单id',
  `user_id` varchar(64) DEFAULT NULL COMMENT '买家id',
  `user_phone` varchar(32) DEFAULT NULL COMMENT '下单钉钉绑定的手机号',
  `belong_group` char(1) DEFAULT NULL COMMENT '订单所属1:总部 2:子集团',
  `type` varchar(1) DEFAULT NULL COMMENT '订单类型1:订餐2:活动',
  `child_type` int(11) DEFAULT NULL COMMENT '订单子类型1:午餐2: 晚餐',
  `pay_status` char(1) DEFAULT NULL COMMENT '订单支付状态1:未支付2已支付',
  `status` char(1) DEFAULT NULL COMMENT '订单状态1:待支付2:待取餐3:已完成4:已取消',
  `total_amount` decimal(12,2) DEFAULT NULL COMMENT '总金额',
  `pay_time` datetime DEFAULT NULL COMMENT '支付时间',
  `create_time` datetime DEFAULT NULL COMMENT '创建时间',
  `take_time` date DEFAULT NULL COMMENT '取餐时间',
  `canteen_id` int(11) DEFAULT NULL COMMENT '餐厅id',
  `payway_id` char(1) DEFAULT NULL COMMENT '支付方式1支付宝2饭卡',
  `meal_code` varchar(32) DEFAULT NULL COMMENT '取餐码',
  `qrcode_img_path` varchar(200) DEFAULT NULL COMMENT '取餐二维码',
  `user_name` varchar(64) DEFAULT NULL COMMENT '买家名称',
  `activity_id` int(11) DEFAULT NULL COMMENT '活动id',
  `activity_name` varchar(32) DEFAULT NULL COMMENT '活动名称',
  PRIMARY KEY (`order_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='订单信息表 ';

order_detail-订单明细表

CREATE TABLE `order_detail` (
  `id` int(11) NOT NULL AUTO_INCREMENT COMMENT 'id',
  `order_id` varchar(32) DEFAULT NULL COMMENT '订单id',
  `item_id` int(11) DEFAULT NULL COMMENT '商品id',
  `item_name` varchar(32) DEFAULT NULL COMMENT '商品名称',
  `price` decimal(12,2) DEFAULT NULL COMMENT '商品单价',
  `num` int(11) DEFAULT NULL COMMENT '商品数量',
  `amount` decimal(12,2) DEFAULT NULL COMMENT '商品总价',
  `parent_id` int(11) DEFAULT NULL COMMENT '上级id 订餐订单为菜单详情id,活动订单为活动详情id',
  `item_type` varchar(32) DEFAULT NULL COMMENT '商品类型 1:普通套餐2:特色套餐3:单品',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=236 DEFAULT CHARSET=utf8 COMMENT='订单明细表 ';

现有一个接口需求要求导出EXCEL格式如下:

在这里插入图片描述

关于商品信息一对多关系,通过SQL字符串分组拼接解决:

SELECT i.order_id AS orderId, GROUP_CONCAT(d.item_name, '×', d.num, CHAR(10 using utf8)) AS itemInfo, i.create_time AS createTime, i.user_name AS userName, i.user_phone AS userPhone, i.status AS status, i.total_amount AS totalAmount
 FROM order_info i
 LEFT JOIN order_detail d
 ON i.order_id = d.order_id GROUP BY i.order_id ORDER BY i.order_id ASC;

运行结果:

在这里插入图片描述


欢迎关注公众号:c_302888524
在这里插入图片描述

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MySQL,有两种常用的方法可以进行字符串拼接。首先是使用`CONCAT`函数,它可以将多个字符串连接在一起。例如,`CONCAT('string1', 'string2', 'string3')`会返回一个由这三个字符串拼接而成的结果。这种方式是无缝拼接的。 其次是使用`CONCAT_WS`函数,它在拼接字符串时可以指定一个分隔符。例如,`CONCAT_WS('/', 'string1', 'string2', 'string3')`会返回一个由这三个字符串以斜杠作为分隔符拼接而成的结果。这种方式是带缝拼接的。 如果你想在MySQL存储过程进行字符串拼接,可以借助这两个函数来实现。下面是一个示例存储过程,演示了如何使用循环和查询来进行字符串拼接,并将结果更新到表的某一行记录。 首先,我们定义了一些变量,包括要拼接字符串查询结果的局部变量等等。然后,我们使用`DECLARE`语句定义了一个游标`report`,并通过`SELECT`语句从表查询数据。接着,我们使用`DECLARE CONTINUE HANDLER`语句设置了循环结束条件。然后,我们打开游标,并使用`FETCH`语句将查询结果赋值给相应的变量。接下来,我们使用`WHILE`循环进行拼接操作,将查询结果逐个拼接字符串。最后,我们关闭游标,并使用`UPDATE`语句将拼接好的字符串更新到表的指定行记录。 通过这个示例,你可以根据自己的具体需求修改存储过程来完成字符串拼接的操作。希望对你有所帮助。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值