• 技术文章 >后端开发 >php教程

    如何做数据库的行列转置

    2016-06-23 13:39:38原创746

    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);

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    上一篇:帝国cms自定义页面上传图片功能如何修改 下一篇:自己动手写 PHP MVC 框架(40节精讲/巨细/新人进阶必看)

    相关文章推荐

    • 手写PHP API框架(二)之Composer的安装使用• 手写PHP API框架(三)之反射介绍• 手写PHP API框架(一)之PSR规范• 聊聊php怎么让Swoole/Pool进程池实现Redis持久连接• 一文解析PHP元转分的错误示范(附代码实例)
    1/1

    PHP中文网