PHP/PDO/MSSQL如何获取错误信息?

Mic*_*ael 11 php sql-server pdo

我做了很多搜索,但找不到任何有关我的问题的信息.我正在使用PDODriver PDO_DBLIB来访问MS SQL数据库.我通常使用预准备语句,但如果任何查询失败,我不会获得有关错误的任何其他信息,除非:

General SQL Server error: Check messages from the SQL Server [241] (severity 16) [(null)]

有没有人提示如何检索有关错误的更多信息(语法错误在......)?

最好的祝福

迈克尔

Pon*_*ife 15

要查找错误消息:

-- SQL 2005+
select * from sys.messages where message_id = 241
-- SQL 2000
select * from sysmessages where error = 241
Run Code Online (Sandbox Code Playgroud)

由于某种原因,PDO似乎正在删除实际的错误消息文本,但由于文档说PDO_DBLIB是实验性的,这可能只是一个错误.

您还应该知道,自SQL 2005以来,Microsoft 已弃用 DBLIB ,因此您几乎肯定会使用不同的库来连接到MSSQL.

  • 有没有办法获取上下文参数?示例:`将%1值%2转换为数据类型%3.`时转换失败 (5认同)