Python 不能修改 MySQL 但用户可以

标签 python mysql python-2.7

抱歉,如果这个问题很愚蠢,我已经学习了 2 天 python

我一直在用头撞墙试图理解为什么我的 python 脚本可以运行 SELECT 语句但不能运行 UPDATEDELETE 语句。

我相信这将是一个 MySQL 问题,而不是一个 Python 问题,但我无法再进行故障排除

pcheck.py

import re
import time
import json
import MySQLdb
import requests
from array import *

conn = MySQLdb.connect([redacted])
cur = conn.cursor()

sql1 = "SELECT pkey,pmeta FROM table1 WHERE proced = 0 LIMIT 1"
cur.execute(sql1)
row = cur.fetchone()
while row is not None:
    print "row is: ",row[0]
    rchk = [
     r"(SHA256|MD5)",
     r"(abc|def)"
     ]
    for trigger in rchk:
        regexp = re.compile(trigger)
        pval = row[1]
        if regexp.search(pval) is not None:
            print "matched on: ",row[0]
            sql2 = """INSERT INTO table2 (drule,dval,dmeta) VALUES('%s', '%s', '%s')"""
            try:
                args2 = (trigger, pval, row[1])
                cur.execute(sql2, args2)
                print(cur._last_executed)
            except UnicodeError:
                print "pass-uni"
            break
    else:
        pass

    sql3 = """UPDATE table1 SET proced=1 WHERE pkey=%s"""
    args3 = row[0]
    cur.execute(sql3, args3)
    print(cur._last_executed)
    row = cur.fetchone()

sql3 = """DELETE FROM table1 WHERE proced=1 AND last_update < (NOW() - INTERVAL 6 MINUTE)"""
cur.execute(sql3)
print(cur._last_executed)
cur.close()
conn.close()
print "Finished"

以及实际(和出人意料的预期)输出:

输出

scrape@:~/python$ python pcheck.py 
row is:  0GqQ0d6B
UPDATE table1 SET proced=1 WHERE pkey='0GqQ0d6B'
DELETE FROM table1 WHERE proced=1 AND last_update < (NOW() - INTERVAL 6 MINUTE)
Finished

但是,数据库没有被更新。我检查了查询是否发送到 MySQL:

MySQL 日志

"2015-12-14 22:53:56","localhost []","110","0","Query","SELECT `pkey`,`pmeta` FROM `table1` WHERE `proced`=0 LIMIT 200"
"2015-12-14 22:53:57","localhost []","110","0","Query","UPDATE `table1` SET `proced`=1 WHERE `pkey`='0GqQ0d6B'"
"2015-12-14 22:53:57","localhost []","110","0","Query","DELETE FROM table1 WHERE proced=1 AND last_update < (NOW() - INTERVAL 6 MINUTE)"

但是 proced 行 0GqQ0d6B 的值仍然不是 1

如果我通过 Sqlyog(以用户身份登录)进行相同的查询,查询将按预期工作。

最佳答案

这类问题可能会非常令人沮丧。你确定这里没有多余的空格吗?

print "row is:*"+row[0]+"*"

也许注释掉

for trigger in rchk:

部分,并在周围撒上一些打印语句?

关于Python 不能修改 MySQL 但用户可以,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34278172/

相关文章:

python - TensorFlow:Compat 弃用警告

python - 不同的 Celery 实例对象使用相同的代理 - 这是一个好的实践吗?

python - 如何根据字典中的键/值增加 Python Pandas DataFrame

python - 如何修复重新声明的警告?

php - Mysql突然停止并且无法重新启动

python - 在 Dash 框架中动态添加 HTML 输入

python - 在 Python 中,如何确定对象是否仍然存在?

python - Python 中的无监督随机森林邻近性

mysql - 我可以从另一个数据库填充一个数据库吗

php - 哪个更快,纯 HTML 还是来自数据库的存储 HTML?