将NaN值插入MySQL数据库

时间:2017-08-18 12:23:05

标签: python mysql python-2.7 mysql-python

我有一些数据包含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的情况下执行此操作?这可能吗?

2 个答案:

答案 0 :(得分:2)

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

答案 1 :(得分:1)

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