MySQLdb为`INT`的`sum`返回`Decimal`

时间:2013-06-09 03:11:54

标签: python mysql mysql-python temp-tables

这是我用来重现问题的表定义:

create table test_sum_type 
(
  kind char(1) not null,
  n tinyint not null
);

测试数据:

+------+---+                                                                                                                                                                                                    
| kind | n |                                                                                                                                                                                                    
+------+---+                                                                                                                                                                                                    
| A    | 1 |                                                                                                                                                                                                    
| B    | 1 |                                                                                                                                                                                                    
| A    | 2 |                                                                                                                                                                                                    
+------+---+  

使用MySQLdb进行查询:

In [32]: cur.execute("select kind, sum(n) from test_sum_type group by kind")                                                                                                                                    
Out[32]: 2L                                                                                                                                                                                                     

In [33]: cur.fetchall()                                                                                                                                                                                         
Out[33]: (('A', Decimal('3')), ('B', Decimal('1')))                                                                                                                                                             

In [34]: cur.execute("select kind, n from test_sum_type")                                                                                                                                                       
Out[34]: 3L                                                                                                                                                                                                     

In [35]: cur.fetchall()                                                                                                                                                                                         
Out[35]: (('A', 1), ('B', 1), ('A', 2))  

如您所见,当我使用Decimal时,结果列为sum

我查看了MySQLdb的源代码,默认情况下只设置了两种字段类型转换为DecimalDECIMALNEWDECIMAL

这可能是什么原因?有没有办法检查特定查询中使用的某些临时表的模式?

1 个答案:

答案 0 :(得分:5)

它是MySql中的设计。

  

<强> GROUP BY (Aggregate) Functions
   SUM()和AVG()函数返回精确值的DECIMAL值   参数(整数或DECIMAL)和DOUBLE值   近似值参数(FLOAT或DOUBLE)。 (在MySQL 5.0.3之前,   SUM()和AVG()为所有数字参数返回DOUBLE。)

如果您需要返回INT,那么请CAST

SELECT kind, CAST(SUM(n) AS SIGNED) n 
  FROM table1 
 GROUP BY kind

这是 SQLFiddle 演示