转:http://blog.chinaunix.net/uid-7692530-id-2567582.html 在某些数据库中有交叉表,但在MySQL中却没有这个功能,但网上看到有不少朋友想找出一个解决方法,特发贴集思广义.http://topic.csdn.net/u/20090530/23/0b782674-4b0b-4cf5-bc1a-e8914aaee5ab.html?96198现整理解法如下: 数据样本: create table tx( id int primary key, c
动态,适用于列不确定情况,第一种: SET @EE=''; SELECT GROUP_CONCAT('SUM(IF(C2=\'',C2,'\'',',C3,0)) AS ',C2)INTO @EE FROM (SELECT DISTINCT C2 FROM TX) A; SET @QQ=CONCAT('SELECT ifnull(c1,\'total\') as ''合计'',',@EE,' ,SUM(C3) AS TOTAL FROM TX GROUP BY C1 WITH ROLLUP');
列变成行 测试数据库数据样式: 应用的sql语句: SELECT TM,NAME,SUM(GE) AS 'GE',SUM(GD) AS 'GD',SUM(CT) AS 'CT',SUM(NUM) AS 'NUM' FROM ( SELECT a.tm,a.Name, (CASE WHEN DH='GE' THEN 1 ELSE 0 END) AS 'GE', (CASE WHEN DH='GD' THEN 1 ELSE 0 END) AS 'GD', (CASE WHEN DH='CT' THE
1.列转行 select class_id,MAX(CASE kemu when '语文' then score ELSE 0 end)as '语文' ,MAX(CASE kemu when '数学' then score ELSE 0 end)as '数学' ,MAX(CASE kemu when '英语' then score ELSE 0 end)as '英语' FROM scoreinfo GROUP BY stuent_id 2.依据查询的结果机创建一个新表 CREATE table
行列转换常见场景 由于很多业务表因为历史原因或者性能原因,都使用了违反第一范式的设计模式.即同一个列中存储了多个属性值(具体结构见下表). 这种模式下,应用常常需要将这个列依据分隔符进行分割,并得到列转行的结果. 表数据: ID Value 1 tiny,small,big 2 small,medium 3 tiny,big 期望得到结果: ID Value 1 tiny 1 small 1 big 2 small 2 medium 3 tiny 3 big 具体方法 先从一个具体实例开始我们的
create table score( name ), math int, english int ); ,); ,); ,); ,); SHOW tables; SELECT * from score; --行列转换: select c2 as '课程', )) '甲', )) '乙', )) '丙', )) '丁' from( select name c1,'math' c2,math c3 from score GROUP BY name union select name,'englis
今天在工作的时候遇到了行列转换的问题,记得去年有一段时间经常写,但是许久不用已经记不太得了.好记性不如烂笔头,忙完之后赶紧记录一下. 关键字:PIVOT(行转列),UNPIVOT(列转行) 先说说 PIVOT(行转列)这是我今天遇到的问题 PIVOT(行专列) 主要语法:PIVOT(聚合函数(列) FOR 列 in (…) )AS P 完整语法: table_source PIVOT( 聚合函数(value_column) FOR pivot_column IN(<column_list>)