MySQL 创建数据透视查询
示例
MySQL没有提供创建透视查询的内置方法。但是,可以使用准备好的语句来创建它们。
假设表tbl_values:
请求:创建一个查询,显示Value每个查询的总和Name;的Group必须是列标题,Name必须是行标题。
-- 1. Create an expression that builds the columns
set @sql = (
select group_concat(distinct
concat(
"sum(case when `Group`='", Group, "' then `Value` end) as `", `Group`, "`"
)
)
from tbl_values
);
-- 2. Complete the SQL instruction
set @sql = concat("select Name, ", @sql, " from tbl_values group by `Name`");
-- 3. Create a prepared statement
prepare stmt from @sql;
-- 4. Execute the prepared statement
execute stmt;结果:
重要提示:不再需要准备好的语句时,请对其进行分配:
deallocate prepare stmt;
SQL小提琴上的示例
热门推荐
10 对患者生日祝福语简短
11 结婚祝福语简短装备
12 周岁祝福语学生文案简短
13 订婚领证祝福语简短精辟
14 导师获奖祝福语大全简短
15 新婚购房祝福语简短精辟
16 牛年祝福语简短的爱人
17 送芒果的祝福语简短
18 送给学长毕业祝福语简短