将 NaN 值插入 MySQL 数据库

2023-12-21

我有一些数据包含 NULL、浮点数和偶尔的 Nan。我正在尝试使用 python 和 MySqldb 将此数据插入到 MySQL 数据库中。

这是插入语句:

for row in zip(currents, voltages):
        row = [id] + list(row)
        for item in row:
            sql_insert = ('INSERT INTO result(id, current, voltage)'
                            'VALUES(%s, "%s")')
            cursor.execute(sql_insert, row)

这是表:

CREATE TABLE langmuir_result (result_id INT auto_increment, 
                              id INT, 
                              current FLOAT,
                              voltage FLOAT,
                              PRIMARY KEY (result_id));

当我尝试将 NaN 插入表中时,出现此错误:

_mysql_exceptions.DataError: (1265, "Data truncated for column 'current' at row 1")

我想将 NaN 值作为浮点或数字插入数据库,而不是字符串或 NULL。我尝试将列的类型设置为 FLOAT 和 DECIMAL,但出现相同的错误。如何在不将其设置为字符串或 NULL 的情况下执行此操作?那可能吗?


不,Mysql 中不可能在 FLOAT 类型列中存储 NaN 值。允许的值只能是 NULL 或数字。您可以使用一些不用于 NaN 的值来解决它(可能是负数,大/低值)

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

将 NaN 值插入 MySQL 数据库 的相关文章

随机推荐