我試圖將行值轉換爲列名。在stackoverflow上搜索後,我知道它可以通過使用GROUP_CONCAT()來完成。我嘗試過但沒有結果。select * transform row value as table列名
我想要什麼?
我有這樣的一個表:
id | staff_id_staff | leave_type_id_leave_type | days
1 | 41 | Casual | 7
2 | 41 | Earned | 1
3 | 41 | Sick | 4
,並希望結果是這樣的:
Casual | Earned | Sick
7 | 1 | 4
請注意:我不知道的leave_type_id_leave_type
值(這將是任何東西)
這裏是leave_remain表的代碼:
CREATE TABLE IF NOT EXISTS `leave_remain` (
`id_leave_remain` int(11) NOT NULL AUTO_INCREMENT,
`staff_id_staff` int(11) NOT NULL,
`leave_type_id_leave_type` int(11) NOT NULL,
`days` float DEFAULT NULL,
`updated` date DEFAULT NULL,
PRIMARY KEY (`id_leave_remain`),
UNIQUE KEY `leave_type_id_leave_type_UNIQUE` (`leave_type_id_leave_type`),
KEY `fk_leave_remain_staff1` (`staff_id_staff`),
KEY `fk_leave_remain_leave_type1` (`leave_type_id_leave_type`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1 AUTO_INCREMENT=108 ;
--
-- Dumping data for table `leave_remain`
--
INSERT INTO `leave_remain` (`id_leave_remain`, `staff_id_staff`, `leave_type_id_leave_type`, `days`, `updated`) VALUES
(82, 41, 16, 16, '2013-02-04'),
(89, 41, 17, 178, '2013-02-06'),
(107, 41, 18, 0, '2013-02-04');
如果您不知道leave_type_id_leave_type的潛在值,那麼您可能需要使用動態SQL。看到這篇文章:http://stackoverflow.com/a/12005676/1073631 – sgeddes