我将mysql连接器python包用于flask中的一个项目。对于注册路由部分,我希望mysql检查用户名是否已经存在,如果已经存在,我将设置一个错误。我的代码如下所示:
@bp.route('/signup', methods=('POST',))
def signup():
...
username = reqObj["username"]
password = reqObj["password"]
error = None
db = get_db()
cursor = db.cursor()
query = ("SELECT * FROM userinfo "
"WHERE username=%s")
existingUser = cursor.execute(query, (username,)).fetchone()
if existingUser is not None:
error = "Username already exists"
if error is None:
cursor.execute(
'INSERT INTO userinfo (username, password) VALUES (%s, %s)',
(username, generate_password_hash(password))
)
cursor.close()
db.commit()
res = {'actionSuccess': True}
return jsonify(res)
else:
res = {'actionSuccess': False, 'error': error}
return jsonify(res)
函数的作用是:返回mysql.connector.connect()对象。但是,当我在服务器上运行并测试它时,flask中会出现一个错误:
...
existingUser = cursor.execute(query, (username,)).fetchone()
AttributeError: 'NoneType' object has no attribute 'fetchone'
所以我想我的错误在cursor.execute()的某个地方,我猜它返回了一个nonetype。因此,我删除了fetchone()函数并重试,但现在却出现以下错误:
...
File "e:\flasktest2\lib\site-packages\mysql\connector\connection.py", line 1128, in handle_unread_result
raise errors.InternalError("Unread result found")
mysql.connector.errors.InternalError: Unread result found
这更让人困惑,因为它现在说有未读的结果,而刚才cursor.execute()是一个nonetype。我不知道是什么导致了这个错误。然后我试着注解掉整个selectquery部分,只是测试了一下insert是否有效,果然有效。是什么导致了我的错误?
1条答案
按热度按时间bvuwiixz1#
显然,对于mysql连接器,cursor.execute(…)将返回none,不管执行语句的结果是什么。但是,结果将存储在cursor对象本身中,即使结果是一个空集。在使用游标对新连接执行新语句之前,还必须获取当前查询的所有结果。这意味着:
相对于: