繁体   English   中英

python中的MySQL。 插入查询不起作用

[英]MySQL in python. Insert query does not work

我对MySQL的INSERT查询有问题。

这是我的python代码:

import socket
import MySQLdb

    def create_db():
         db1 = MySQLdb.connect(host="localhost",user="root",passwd="root")
         cursor = db1.cursor()
         sql = 'CREATE DATABASE IF NOT EXISTS  env_data;'
         select_db = 'USE env_data'
         ins = "insert into env_data(cpu_usage, date, mem_usage) values('40%', '1999-01-01 11:11:11', '25%');"
         engine_db = "set sql_mode='NO_ENGINE_SUBSTITUTION'"
         us = 'CREATE TABLE IF NOT EXISTS env_data (id INT NOT NULL AUTO_INCREMENT PRIMARY KEY,date datetime NOT NULL,cpu_usage varchar(10) NOT NULL,mem_usage varchar(10) NOT NULL);'
         cursor.execute(select_db)
         cursor.execute(us)
         cursor.execute(engine_db)
         cursor.execute(ins)

执行后,将正确创建数据库和表,但是插入无效。 当我在mysql服务器中执行此查询时,它可以工作,但是从此python脚本开始-cpu_usage,date,mem_usage中没有插入。

在脚本中,我还尝试执行mysql_notes = 0 / mysql_notes = 1

请问有人可以帮助我解决这个问题吗?

您必须在插入语句之后添加db1.commit() 这在mysql工作台/命令行中有效,因为它具有自动提交选项,默认情况下设置为true 否则,您将必须执行相同操作。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM