ホームページ > バックエンド開発 > PHPチュートリアル > データベースの行と列を入れ替える方法

データベースの行と列を入れ替える方法

WBOY
リリース: 2016-06-23 13:39:38
オリジナル
1304 人が閲覧しました

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.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート