如何获取发送到db的准备好的查询

时间:2013-07-11 10:52:38

标签: python pyodbc python-db-api

当使用实现pyodbcPython Database API Specification等数据库库时,如何在应用参数替换后获得完全准备好的查询。我正在调用一个Sybase存储过程,它将通过参数替换接收18个参数。我想捕获所做的实际调用并将其记录以帮助调试。我需要的一个更简单的例子:

pyodbc示例

import pyodbc
conn = pyodbc.connect('DSN=test;PWD=password')
c = conn.cursor()
c.execute('CREATE TABLE stocks (symbol varchar(10), price real)')
c.execute("INSERT INTO stocks VALUES (?, ?)", ('RHAT', 35.14))
c.execute('SELECT * FROM stocks WHERE symbol=?', ('RHAT',))
print c.fetchone()

预期的最终查询(待记录)

CREATE TABLE stocks (symbol varchar(10), price real)
INSERT INTO stocks VALUES ('RHAT', 35.14)
SELECT * FROM stocks WHERE symbol = 'RHAT'

sqlite3示例

import sqlite3
conn = sqlite3.connect(':memory:')
c = conn.cursor()
c.execute('CREATE TABLE stocks (symbol text, price real)')
c.execute("INSERT INTO stocks VALUES (?, ?)", ('RHAT', 35.14))
c.execute('SELECT * FROM stocks WHERE symbol=?', ('RHAT',))
print c.fetchone()

我已经放了sqlite3示例,因为它不需要pyodbc来试用它。

更新

似乎当使用prepared statements时,将数据填充到模板中的过程在DBMS中完成服务器端。因此,经常没有方法或api从服务器获取查询的最终版本,如user581592的答案中所述。其他值得注意的链接是pyodbc上的Issue 163,进一步讨论了这一点。另外一些像psycopg这样的db库添加了一个返回最终语句的方法mogrify。但正如他们的文档中所提到的,这不是DB API的一部分。

1 个答案:

答案 0 :(得分:5)

来自https://groups.google.com/forum/#!topic/pyodbc/656mRdbjFuc

  

pyodbc不会以任何方式修改SQL。通常,“好的”ODBC驱动程序也不会。

     

由于它不是受支持的函数,因此没有用于检索最终SQL的ODBC函数,因此pyodbc无法提供此函数。

因此,您最好的选择可能是在脚本中单独记录查询和参数,或者如果可行,您可以尝试在数据库上配置某种级别的查询日志记录。