Testing数据库表中的number列显然具有整数数据类型。您可以通过查询EXPLAIN Testing来检查数据类型。如果它有整数数据类型,number值在存储到表中之前被强制为整数。在
如果要存储十进制数,则需要先更改表:ALTER TABLE `Testing` CHANGE `number` `number` DECIMAL(M,D)
其中(perthe docs):M是最大位数(精度)。它的范围是1到65。
D是小数点(刻度)右边的位数。它
范围为0到30,并且不能大于M。
例如,如果我们创建一个Testing表,其中number具有INT(11)数据类型:
^{pr2}$
假设该表有一条记录number = 5:insert = 'INSERT INTO Testing (number) VALUE (%s)'
cursor.execute(insert, (5,))
show_table(cursor)
# (1L, 5L)
如果我们试图将number设置为5.5:update = 'UPDATE Testing SET number = %s where id = %s'
cursor.execute(update, [5.5, 1])
相反,数字存储为6:show_table(cursor)
# (1L, 6L)
如果我们将number字段的数据类型更改为DECIMAL(8,2):alter = 'ALTER TABLE `Testing` CHANGE `number` `number` DECIMAL(8,2)'
cursor.execute(alter)
然后将数字设置为5.5将存储number作为十进制:cursor.execute(update, [5.5, 1])
show_table(cursor)
# (1L, Decimal('5.50'))
当然,也可以创建一个Testing表,从一开始就使用十进制数据类型的number字段,然后从一开始就将浮点数存储为小数。在
我不太清楚你是否真的想要一个DECIMAL(M,D)数据类型。如果使用DECIMAL(M,D),那么查询表将返回numbers,在Python端是decimal.Decimals。如果您只需要常规的Python浮点数,那么用数据类型为FLOAT而不是DECIMAL(M,D)的Testing字段定义{}。在