php如何将行列置换,如何做数据库的行列转置

thinkphp和mysql。数据库如图所示:

建表的sql语句如下:

CREATE TABLE `score_collect` ( `std_id` int(10) NOT NULL, `course_id` int(11) NOT NULL, `score` varchar(255) DEFAULT NULL, PRIMARY KEY (`std_id`,`course_id`), )

INSERT INTO `score_collect` VALUES ('2012508082', '2', '20'); INSERT INTO `score_collect` VALUES ('2012508082', '3', '10'); INSERT INTO `score_collect` VALUES ('2012508082', '4', '30'); INSERT INTO `score_collect` VALUES ('2012508084', '2', '21'); INSERT INTO `score_collect` VALUES ('2012508084', '3', '11'); INSERT INTO `score_collect` VALUES ('2012508084', '4', '31');

需要实现的是将上图中的数据调整为这样在前台显示出来:

其中,表行数不固定。std_id和course_id也不固定。

(不知道我把问题表达清楚了没有)。用php也可以,但是我想最好还是用sql语句吧。当然。。能兼顾性能最好。

跪求各路大神解决,谢谢。

另外祝大家春节快乐,万事如意。 谢谢

回复讨论(解决方案)

SELECT std_id,GROUP_CONCAT(course_id) AS course_id,GROUP_CONCAT(score) AS score FROM `score_collect` GROUP BY std_id;

//$list=array(array('std_id'=>'2012508082','course_id'=>'2,3,4','score'=>'20,10,30'),array('std_id'=>'2012508084','course_id'=>'2,3,4','score'=>'21,11,31'),);foreach($list as $key=>$val){$course_id_arr=explode(',',$val['course_id']);$score_arr=explode(',',$val['score']);unset($list[$key]['course_id']);unset($list[$key]['score']);foreach($course_id_arr as $key1=>$val1){$list[$key][$val1]=$score_arr[$key1];}}print_r($list);

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值