将NaN值插入MySQL数据库
我有一些数据,其中包含空值、浮点数和偶尔的NAN。我正在尝试使用python和MySqldb将这些数据插入到MySQL数据库中。
以下是INSERT语句:
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,但得到了相同的错误。如何才能在不将其设置为字符串或空的情况下执行此操作?这可能吗?
解决方案
不能,在mySQL的浮点型列中不能存储NaN值。允许的值仅为空或数字。您可以使用一些不用于NaN的值来解决它(可能是负值,大/低值)
相关文章