python - 获取特定表的所有数据库名称并对每个结果运行查询
问题描述
我正在尝试对包含特定表的所有数据库运行查询,并在 python 中使用 pymysql。我正在创建一个游标,并且能够获取我想要对其运行查询的所有数据库的结果集。我在尝试将这些数据库名称传递到我的查询时遇到问题。
我已经尝试过使用pymysql.cursors.DictCursor
和pymysql.cursors.Cursor
存储结果,但是当我尝试遍历结果行并将它们传递给USE
语句中的占位符或进行查询时,就像SELECT * from dbname.tablename
我遇到语法错误一样,它在数据库名称周围加上单引号。
import pymysql
import pymysql.cursors
conn = pymysql.connect(host, username, password)
cur = conn.cursor(pymysql.cursors.DictCursor)
sql_find_db = "SELECT distinct TABLE_SCHEMA FROM `information_schema`.`TABLES` WHERE TABLE_NAME = 'tbl_special_table'"
cur.execute(sql_find_db)
cur2 = conn.cursor(pymysql.cursors.Cursor)
for row in cur:
db = row['TABLE_SCHEMA']
cur2.execute("USE %s", db)
sql_query = "SELECT * FROM some_table"
result = cur2.execute(sql_query)
print(result)
我希望这会打印 的结果SELECT * FROM db.some_table
,但我得到:
您的 SQL 语法有错误;检查与您的 MySQL 服务器版本相对应的手册,以获取在第 1 行的“数据库_0”附近使用的正确语法”)
解决方案
您不能为数据库、表或列名使用占位符,您必须使用正常的字符串格式。例如,您可以使用 f 字符串:
cur2.execute(f"USE `{db}`")
推荐阅读
- c++ - 使用 std::error_code - 在可能的错误情况后我应该调用 .clear() 吗?
- react-native - React Native 上 Android 设备的布局/尺寸问题
- javascript - 在 Gatsby,Graphql 中以 HH:MM:SS 格式查找持续时间字段的最大值
- python - 不知道为什么我得到“TypeError:只能将str(不是“int”)连接到str”
- python - 在 3d numpy 数组中的一系列 2d 子数组上执行函数的更有效方法是什么?
- hadoop - n gram Wordcount prblem:Mapreduce链接多个地图
- java - 输入信息时如何检测空行
- reactjs - 如何在父模态组件之上打开 React-Bootstrap 模态组件(子模态)同时隐藏父模态?
- html - 如何在css中为内容图像设置宽度和高度
- python - Tkinter 未按预期显示窗口信息