检查查询是不是通过python成功运行

Posted

技术标签:

【中文标题】检查查询是不是通过python成功运行【英文标题】:Check if query run successfully through python检查查询是否通过python成功运行 【发布时间】:2015-07-09 06:21:03 【问题描述】:

我有一个包含所有 mysql 查询的 .sql 脚本。现在假设在执行脚本后我想检查查询是否成功运行。如果我们这样做,在命令行中

echo $?

如果查询成功则返回0,不成功则返回1。

不,我想用 python 脚本来做。如何才能做到这一点 ?

我的python脚本:

import mysql.connector
from mysql.connector import errorcode

try:
    cnx = mysql.connector.connect(user='myuser', password='mypass', host='127.1.2.3', database='mydb')
except mysql.connector.Error as err:
    if err.errno == errorcode.ER_ACCESS_DENIED_ERROR:
        print("Something is wrong with your user name or password")
    elif err.errno == errorcode.ER_BAD_DB_ERROR:
        print("Database does not exist")
    else:
        print(err)
else:
    cursor = cnx.cursor()
    cursor.executescript("sql_queries.sql")
    cnx.close()

【问题讨论】:

【参考方案1】:

您是说在运行脚本后让 python 返回退出代码吗?你想阅读sys.exit

在您的示例中,您可能会有类似

except mysql.connector.Error as err:
    if err.errno == errorcode.ER_ACCESS_DENIED_ERROR:
    ...
    sys.exit(1)
else:
    cursor = cnx.cursor()
    # Might want to check whether the executescript was successful
    try:
        cursor.executescript("sql_queries.sql")
    except mysql.connector.Error as err:
        print(err)
        sys.exit(1)
    cnx.close()

当然,前段时间有人问过这个问题,还有其他相关问题:

Exit codes in Python Exit code when python script has unhandled exception Setting exit code in Python when an exception is raised

还请考虑将错误消息发送到 stderr,而不是将默认的 print() 留给 stdout,请参阅:

How to print to stderr in Python?

【讨论】:

我想检查我的 .sql 文件中的特定查询。假设我想检查某些插入是否正确' 见:***.com/questions/9014233/…

以上是关于检查查询是不是通过python成功运行的主要内容,如果未能解决你的问题,请参考以下文章

如何检查 SQL 脚本是不是在 MS SQL Server 中成功执行?

MySQLi PHP:使用 MySQLi 检查 SQL INSERT 查询是不是完全成功

.net ef core 检查是不是插入成功

.net ef core 检查是不是插入成功

如何检查连接刷新是不是成功

如何知道mysql是不是安装成功?