Python 获取具有特定表的所有DB名称,并对每个结果运行查询

Python 获取具有特定表的所有DB名称,并对每个结果运行查询,python,pymysql,Python,Pymysql,我试图用pymysql在python中对包含某个表的所有数据库运行查询。我正在创建一个游标,并且能够获得我想要对其运行查询的所有数据库的结果集。我在尝试将这些数据库名称传递到查询时遇到问题 我尝试使用pymysql.cursors.DictCursor和pymysql.cursors.Cursor来存储结果,但是,当我尝试循环遍历结果行并将它们传递给USE语句中的占位符,或者使用类似SELECT*from dbname.tablename的查询时,会出现语法错误,即在数据库名称周围加上单引号 i

我试图用pymysql在python中对包含某个表的所有数据库运行查询。我正在创建一个游标,并且能够获得我想要对其运行查询的所有数据库的结果集。我在尝试将这些数据库名称传递到查询时遇到问题

我尝试使用
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)
我希望这会打印从db.some_table
中选择*的结果,但我得到的是:

您的SQL语法有错误;检查与MySQL服务器版本对应的手册,以了解第1行“database_0”附近使用的正确语法)


不能对数据库、表或列名使用占位符,必须使用普通字符串格式。例如,可以使用f字符串:

cur2.execute(f"USE `{db}`")