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