我有一些数据包含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值作为float或数字插入数据库,而不是字符串或NULL。我已经尝试将列的类型设置为FLOAT和DECIMAL但是得到相同的错误。如何在不使其成为字符串或NULL的情况下执行此操作?这可能吗?
答案 0 :(得分:2)
不,不可能在Mysql的FLOAT类型列中存储NaN值。允许的值仅为NULL或数字。您可以使用一些不用于NaN的值来解决它(可能是负数,大/低值)
答案 1 :(得分:1)
尝试将您的NaN
转换为None
,因为MySQL可以理解None
,并且在UI中您会看到NULL