db_conn = pymysql.connect(autocommit=False, **db_config) TypeError: __init__() got an unexpected keyword argument 'echo'
时间: 2023-07-31 16:06:38 浏览: 64
抱歉,我之前提供的代码有误。在 PyMySQL 中,`echo` 参数是 SQLAlchemy 的一个特性,而不是 PyMySQL 自带的参数。如果要输出 SQL 语句,可以通过设置 PyMySQL 的日志级别来实现。示例代码如下:
```python
import pymysql
import logging
# 设置日志级别为 DEBUG
logging.basicConfig()
logging.getLogger('pymysql').setLevel(logging.DEBUG)
# 创建 Connection 对象并关闭自动提交
db_config = {
'host': 'localhost',
'user': 'root',
'password': 'password',
'db': 'test',
'charset': 'utf8mb4'
}
db_conn = pymysql.connect(autocommit=False, **db_config)
# 创建 Cursor 对象并执行 SQL
with db_conn.cursor() as cursor:
sql = "SELECT * FROM `users` WHERE `name`=%s"
cursor.execute(sql, ('John',))
result = cursor.fetchall()
# 提交事务并关闭 Connection 对象
db_conn.commit()
db_conn.close()
```
在上述代码中,通过设置 `pymysql` 的日志级别为 `DEBUG`,可以在控制台输出完整的 SQL 语句和参数,如下所示:
```
pymysql: DEBUG: SELECT * FROM `users` WHERE `name`='John'
```
需要注意的是,同样地,日志级别的设置应该在开发和测试阶段使用,在生产环境中请勿使用。