sql-server - 如何从 PyMSSQL 捕获异常

标签 sql-server python-3.x exception pymssql

我正在使用 PyMSSQL 连接到数据库。但是,如果我输入了错误的详细信息或存在其他问题,PyMSSQL 会引发异常。但是,我无法弄清楚如何捕获异常。我已经使用了我能想到的所有变体,但我似乎无法以优雅的方式捕获异常。

我的连接代码是:

import pymssql
import getpass

tempServer = input("Enter host: ")
tempUser = input("Enter user: ")
tempPwd = getpass.getpass("Enter password: ")

try:
    phjTempConnection = pymssql.connect(server = tempServer,
                                        user = tempUser,
                                        password = tempPwd,
                                        port = '1433')
except pymssql.MSSQLDatabaseException:
    print("ERROR")

如果我在输入字段中输入无意义的内容,我会得到以下输出:

---------------------------------------------------------------------------
MSSQLDatabaseException                    Traceback (most recent call last)
pymssql.pyx in pymssql.connect (pymssql.c:10734)()

_mssql.pyx in _mssql.connect (_mssql.c:21821)()

_mssql.pyx in _mssql.MSSQLConnection.__init__ (_mssql.c:6581)()

_mssql.pyx in _mssql.maybe_raise_MSSQLDatabaseException (_mssql.c:17524)()

MSSQLDatabaseException: (18456, b'Unknown error')

During handling of the above exception, another exception occurred:

OperationalError                          Traceback (most recent call last)
<ipython-input-21-22d7fd0e3d05> in <module>()
     11                                         password = tempPwd,
---> 12                                         port = '1433')
     13 except pymssql.MSSQLDatabaseException:

pymssql.pyx in pymssql.connect (pymssql.c:10824)()

OperationalError: (18456, b'Unknown error')

During handling of the above exception, another exception occurred:

AttributeError                            Traceback (most recent call last)
<ipython-input-21-22d7fd0e3d05> in <module>()
     11                                         password = tempPwd,
     12                                         port = '1433')
---> 13 except pymssql.MSSQLDatabaseException:
     14     print("ERROR")

AttributeError: 'module' object has no attribute 'MSSQLDatabaseException'

我本以为输出会提供足够的信息,以便能够找出如何捕获 MSSQLDatabaseException 异常,但我尝试了各种变体,但没有成功。

如何使用输出来确定如何捕获引发的异常?

最佳答案

经过一番探索,我找到了一个合理的解决方案。使用原始问题中列出的代码(使用 pymssql.connect() ),出现了两个潜在的异常。如果输入了正确的服务器地址,但用户名或密码不正确,则会引发 MSSQLDatabaseException。但是,如果服务器地址不正确,则会引发 MSSQLDriverException(但请参阅末尾的注释)。要从这些错误中正常退出,似乎有必要捕获 pymssql.InterfaceError (捕获 MSSQLDriverException)和 pymssql.DatabaseError (捕获 MSSQLDatabaseError)。

import pymssql
import getpass

tempServer = input("Enter host: ")
tempUser = input("Enter user: ")
tempPwd = getpass.getpass("Enter password: ")

try:
    phjTempConnection = pymssql.connect(server = tempServer,
                                        user = tempUser,
                                        password = tempPwd,
                                        port = '1433')
except pymssql.InterfaceError:
    print("A MSSQLDriverException has been caught.")

except pymssql.DatabaseError:
    print("A MSSQLDatabaseException has been caught.")

或者,可以捕获使用 _mysql 生成的异常,如注释中的 match 所暗示的那样。 (但是,在这种情况下,随后将数据导入 Pandas 数据帧时会出现问题,因为 _mssql 没有 Cursor 属性。)

import pymssql
import _mssql
import getpass

tempServer = input("Enter host: ")
tempUser = input("Enter user: ")
tempPwd = getpass.getpass("Enter password: ")

try:
    phjTempConnection = _mssql.connect(server = tempServer,
                                       user = tempUser,
                                       password = tempPwd,
                                       port = '1433')

except _mssql.MssqlDriverException:
    print("A MSSQLDriverException has been caught.")

except _mssql.MssqlDatabaseException as e:
    print("A MSSQLDatabaseException has been caught.")
    print('Number = ',e.number)
    print('Severity = ',e.severity)
    print('State = ',e.state)
    print('Message = ',e.message)

希望这对其他人有用。

(注意:如果第一次运行这些函数时输入的 SQL SERVER 地址不正确,则会引发 MSSQLDriverException。如果输入了正确的服务器地址(但用户和密码不正确),则会引发 MSSQLDatabaseException 。但是,如果随后输入了不正确的服务器,则将继续引发 MSSQLDatabaseException,而不是像第一种情况那样引发 MSSQLDriverException。)

关于sql-server - 如何从 PyMSSQL 捕获异常,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48610782/

相关文章:

java - 从文件读取时出现 ArrayIndexOutOfBoundsException

python - 在 Python 中自定义 FileNotFoundError 消息

sql-server - Azman - SQL 存储的连接字符串

SQL Server 聚合性能

python - 如何从 Python 列表中删除标题和索引?

python - 如何解决循环导入错误?

java - 简单的数学到英语计算器

sql-server - 克服在 DataGridView 中显示二进制列的 .NET 问题

sql - 使用 Openrowset 导入错误

python - 是否有任何 Python 3 模块来创建 PDF 文件?