将NaN值插入MySQL数据库

Inserting NaN value into MySQL Database(将NaN值插入MySQL数据库)
本文介绍了将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的值来解决它(可能是负值,大/低值)

这篇关于将NaN值插入MySQL数据库的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

Hibernate reactive No Vert.x context active in aws rds(AWS RDS中的休眠反应性非Vert.x上下文处于活动状态)
Bulk insert with mysql2 and NodeJs throws 500(使用mysql2和NodeJS的大容量插入抛出500)
Flask + PyMySQL giving error no attribute #39;settimeout#39;(FlASK+PyMySQL给出错误,没有属性#39;setTimeout#39;)
auto_increment column for a group of rows?(一组行的AUTO_INCREMENT列?)
Sort by ID DESC(按ID代码排序)
SQL/MySQL: split a quantity value into multiple rows by date(SQL/MySQL:按日期将数量值拆分为多行)