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