create table ty_test(
Name varchar(20) ,
Materialid varchar(50),
Picname varchar(50),
Due int(32)   
);
insert into ty_test values
('zxj','1120','机床','50');
insert into ty_test values
('xj','1110','底板','10');
insert into ty_test values
('zxj','1130','螺丝','20');
insert into ty_test values
('xj','11120','机床','35');
insert into ty_test values
('ty','1110','底板','25');
insert into ty_test values
('ty','1130','螺丝','15');SET @ee='';
SELECT @EE:=CONCAT(@EE,'SUM(IF(`name`=\'',`name`,'\'',',Due,0)) AS ',`name`,',') FROM (SELECT DISTINCT `name` FROM ty_test) A;
SET @QQ=CONCAT('SELECT ifnull(picName,\'total\'),',LEFT(@EE,LENGTH(@EE)-1),',SUM(Due) AS TOTAL FROM ty_test GROUP BY `picname` WITH ROLLUP');
PREPARE stmt2 FROM @QQ;
EXECUTE stmt2;

解决方案 »

  1.   

    上个帖子已经说过了嘛,
    打开SELECT DISTINCT `name` FROM ty_test记录集,循环,字符串累加生成SQL语句,
    再执行,取得执行后的记录集( OR 生成新表)
      

  2.   

    SET @ee='';
    SELECT @EE:=CONCAT(@EE,'SUM(IF(`name`=\'',`name`,'\'',',Due,0)) AS ',`name`,',') FROM (SELECT DISTINCT `name` FROM ty_test) A;
    SET @QQ=CONCAT('SELECT ifnull(picName,\'total\'),',LEFT(@EE,LENGTH(@EE)-1),',SUM(Due) AS TOTAL FROM ty_test GROUP BY `picname` WITH ROLLUP');
    看不懂
      

  3.   

    具体什么地方不懂?
    SELECT @QQ,看看结果
      

  4.   

    SUM(IF(`name`=\'',`name`,'\'',',Due,0),不懂
    LEFT(@EE,LENGTH(@EE)-1),这句看的懂,不知道为什么
      

  5.   

    SUM(IF(`name`=\'',`name`,'\'',',Due,0),不懂
    上次已经说过 ,\转义 ,后面为1个单引号,NAME为字符型 
      

  6.   

    SUM,IF,LEFT,LENGTH,这些函数看不懂就去查手册,说得很清楚。
      

  7.   

    下述示例能否明白:
    select Picname,sum(if(`name`='zxj',due,0)) from ty_test group by Picname
    看看结果
      

  8.   

    看的懂啊,如果name=zxj,则求和due字段
      

  9.   

    SUM(IF(`name`=\'',`name`,'\'',',Due,0),
    就是要生成sum(if(`name`='zxj',due,0))中的部份select Picname,sum(if(`name`='zxj',due,0)) from ty_test group by Picname
      

  10.   

    .1.1. 字符串
    字符串指用单引号(‘'’)或双引号(‘"’)引起来的字符序列。例如:'a string'
    "another string"
    如果SQL服务器模式启用了NSI_QUOTES,可以只用单引号引用字符串。用双引号引用的字符串被解释为一个识别符。字符串可以有一个可选字符集引介词和COLLATE子句:[_charset_name]'string' [COLLATE collation_name]
    例如:SELECT _latin1'string';
    SELECT _latin1'string' COLLATE latin1_danish_ci;
    关于这些字符串语法形式的详细信息,参见10.3.7节,“字符串文字字符集和校对”。在字符串中,某些序列具有特殊含义。这些序列均用反斜线(‘\’)开始,即所谓的转义字符。MySQL识别下面的转义序列:\0 
     ASCII 0(NUL)字符。
     
    \' 
     单引号(‘'’)。
     
    \" 
     双引号(‘"’)。
     
    \b 
     退格符。
     
    \n 
     换行符。
     
    \r 
     回车符。
     
    \t 
     tab字符。
     
    \Z 
     ASCII 26(控制(Ctrl)-Z)。该字符可以编码为‘\Z’,以允许你解决在Windows中ASCII 26代表文件结尾这一问题。(如果你试图使用mysql db_name < file_name,ASCII 26会带来问题)。
     
    \\ 
     反斜线(‘\’)字符。
     
    \% 
     ‘%’字符。参见表后面的注解。
     
    \_ 
     ‘_’字符。参见表后面的注解。
     这些序列对大小写敏感。例如,‘\b’解释为退格,但‘\B’解释为‘B’。‘\%’和‘\_’序列用于搜索可能会解释为通配符的模式匹配环境中的‘%’和‘_’文字实例。参见12.3.1节,“字符串比较函数”。请注意如果你在其它环境中使用‘\%’或‘\_’,它们返回字符串‘\%’和‘\_’,而不是‘%’和‘_’。在其它转义序列中,反斜线被忽略。也就是说,转义字符解释为仿佛没有转义。有几种方式可以在字符串中包括引号:·         在字符串内用‘'’引用的‘'’可以写成‘''’。·         在字符串内用‘"’引用的‘"’可以写成‘""’。·         可以在引号前加转义字符(‘\’)。·         在字符串内用‘"’引用的‘'’不需要特殊处理,不需要用双字符或转义。同样,在字符串内用‘'’引用的‘"’也不需要特殊处理。下面的SELECT语句显示了引用和转义如何工作:mysql> SELECT 'hello', '"hello"', '""hello""', 'hel''lo', '\'hello';
    +-------+---------+-----------+--------+--------+
    | hello | "hello" | ""hello"" | hel'lo | 'hello |
    +-------+---------+-----------+--------+--------+
     
    mysql> SELECT "hello", "'hello'", "''hello''", "hel""lo", "\"hello";
    +-------+---------+-----------+--------+--------+
    | hello | 'hello' | ''hello'' | hel"lo | "hello |
    +-------+---------+-----------+--------+--------+
     
    mysql> SELECT 'This\nIs\nFour\nLines';
    +--------------------+
    | This
    Is
    Four
    Lines |
    +--------------------+
     
    mysql> SELECT 'disappearing\ backslash';
    +------------------------+
    | disappearing backslash |
    +------------------------+
    如果你想要在字符串列内插入二进制数据(例如BLOB),必须通过转义序列表示下面的字符:NUL
     NUL字节(ASCII 0)。用‘\0’表示该字符(反斜线后面跟一个ASCII‘0’字符)。
     
    \
     反斜线(ASCII 92)。用‘\\’表示该字符。
     
    '
     单引号(ASCII 39)。用‘\'’表示该字符。
     
    "
     双引号(ASCII 34)。用‘\"’表示该字符。
     当编写应用程序时,在包含这些特殊字符的字符串用于发送到MySQL服务器的SQL语句中的数据值之前,必须对它们正确进行转义。可以用两种方法来完成:·         用转义特殊字符的函数处理字符串。例如,在C程序中,可以使用mysql_real_escape_string() C API函数来转义字符。参见25.2.3.52节,“mysql_real_escape_string()”。Perl DBI接口提供一个quote方法来将特殊字符转换为正确的转义序列。参见25.4节,“MySQL Perl API”。·         显式转义特殊字符,许多MySQL API提供了占位符功能,允许你在查询字符串中插入特殊标记,然后当你发出查询时将数据值同它们绑定起来。在这种情况下,API关注转义值中的特殊字符。