将 NaN 值插入 MySQL 数据库

Inserting NaN value into MySQL Database

我有一些数据包含 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)

这是table:

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

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

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

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

不,在 Mysql 中无法将 NaN 值存储在 FLOAT 类型的列中。允许的值仅为 NULL 或数字。您可以使用一些您不用于 NaN 的值来解决它(可能是负数,big/low 值)

尝试将您的 NaN 转换为 None,因为 MySQL 理解 None,并且在 UI 中您会看到 NULL

您可以使用:

if pd.isna(row[column]):
      values_data.append(None)
    else:
      values_data.append(row[column])