对数据库进行循环输入时出现异常 Python

got exception when do a loop input to database Python

所以,我想多次输入数据,以自增为主键,以return主键为输入结果。所以这是我的代码:

connectDB.py

import pymysql
class auth:

   db = pymysql.connect("localhost","root","","rfid")

   cursor = db.cursor()

   def inputData(nama):
       sql = "INSERT INTO auth (nama) VALUES ('%s');" % (nama)

       try:
           auth.cursor.execute(sql)
           auth.db.commit()


           result = auth.cursor.lastrowid

           auth.db.close()

           return result
       except:
           err = "Error: unable to fetch data"
           auth.db.rollback()

           auth.db.close()

           return err

test.py

import re
import PyMySQL
from connectDB import auth

while True:

     inputs2 = input("masukan nama: ")


     hasil = auth.inputData(inputs2)

     print(hasil)

所以,当我第一次输入时是成功的,但是当我再次尝试输入时却出现错误异常:

Traceback (most recent call last):
  File "/home/pi/Desktop/learn/RFIDdatabase/connectDB.py", line 29, in inputData
auth.cursor.execute(sql)

  File "/usr/local/lib/python3.4/dist-packages/pymysql/cursors.py", line 166, in execute
result = self._query(query)

  File "/usr/local/lib/python3.4/dist-packages/pymysql/cursors.py", line 322, in _query
conn.query(q)

  File "/usr/local/lib/python3.4/dist-packages/pymysql/connections.py", line 855, in query
self._execute_command(COMMAND.COM_QUERY, sql)

  File "/usr/local/lib/python3.4/dist-packages/pymysql/connections.py", line 1071, in _execute_command
raise err.InterfaceError("(0, '')") 
pymysql.err.InterfaceError: (0, '')

During handling of the above exception, another exception occurred:

Traceback (most recent call last):
  File "test.py", line 12, in <module>
hasil = auth.inputData(inputs2)

  File "/home/pi/Desktop/learn/RFIDdatabase/connectDB.py", line 41, in inputData
auth.db.rollback()

  File "/usr/local/lib/python3.4/dist-packages/pymysql/connections.py", line 792, in rollback
self._execute_command(COMMAND.COM_QUERY, "ROLLBACK")

  File "/usr/local/lib/python3.4/dist-packages/pymysql/connections.py", line 1071, in _execute_command
raise err.InterfaceError("(0, '')")
pymysql.err.InterfaceError: (0, '')

所以,异常原因是什么?

当然你会得到一个异常 - 因为你 执行查询后关闭连接:

auth.cursor.execute(sql)
auth.db.commit()

result = auth.cursor.lastrowid

auth.db.close()  # < HERE

return result

您可能会收到一个 "operation on a closed cursor" 异常,该异常由您过于宽泛的裸 except 子句 (which is bad) 处理 - 然后 - 在 auth.db.rollback() 处启动回滚失败并出现非描述性和不可理解的错误。

其他问题:

  • 我会制作 dbcursor 实例变量 而不是 class 变量 (differences)
  • 不要"string format"你的查询 - proper parameterize them