mysql数据库存储圆形要素_MySQL数据库更新为圆形小数

number数据库表中的Testing列显然具有整数数据类型。您可以通过查询EXPLAIN Testing来检查数据类型。如果它具有整数数据类型,则number值在存储到表中之前被强制转换为整数。

如果您希望存储小数,则需要先更改表格:

ALTER TABLE `Testing` CHANGE `number` `number` DECIMAL(M,D)

M是最大位数(精度)。它的范围是1到65.

D是小数点右边的位数(比例)。它

范围为0到30,且不得大于M。

例如,如果我们创建一个Testing表,number的数据类型为INT(11):

import MySQLdb

import config

def show_table(cursor):

select = 'SELECT * FROM Testing'

cursor.execute(select)

for row in cursor:

print(row)

def create_table(cursor):

sql = 'DROP TABLE Testing'

cursor.execute(sql)

sql = '''CREATE TABLE `Testing` (

`id` INT(11) NOT NULL AUTO_INCREMENT,

`number` INT(11),

PRIMARY KEY (id))'''

cursor.execute(sql)

with MySQLdb.connect(host=config.HOST, user=config.USER,

passwd=config.PASS, db='test') as cursor:

create_table(cursor)

假设该表具有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数据类型,然后浮点数将从头开始存储为小数。

PS。对我来说,如果你真的想要一个DECIMAL(M,D)数据类型,那就不太清楚了。如果您使用DECIMAL(M,D),则查询该表将返回number s,它们是Python端的decimal.Decimal。如果您只想要常规的Python浮点数,那么使用数据类型为Testing而不是number的{​​{1}}字段定义FLOAT。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值