gpt4 book ai didi

python - PyMySQL 在 Python 中将变量分配给表名

转载 作者:行者123 更新时间:2023-11-29 19:24:02 25 4
gpt4 key购买 nike

我在 Python 2.7 中使用 PyMySQL。我必须创建一个函数 - 在给定表名的情况下,查询将找到所有列名的唯一值。

由于涉及多个表,我不想对表名进行硬编码。现在,一个更简单的查询如下:

cursor.execute("  SELECT DISTINCT(`Trend`) AS `Trend` FROM `Table_1`  ORDER BY `Trend` DESC      ")

我想做这样的事情:

tab = 'Table_1'
cursor.execute(" SELECT DISTINCT(`Trend`) AS `Trend` FROM tab ORDER BY `Trend` DESC ")

我收到以下错误:

ProgrammingError: (1146, u"Table 'Table_1.tab' doesn't exist")

有人可以帮忙吗? TIA

最佳答案

确保您使用的数据库正确,并使用%s格式化您的sql语句。

DB_SCHEMA='test_db'
table_name='table1'
connection = pymysql.connect(host=DB_SERVER_IP,
port=3306,
db=DB_SCHEMA,
charset='UTF8',
cursorclass=pymysql.cursors.DictCursor
)
try:
with connection.cursor() as cursor:
sql = "SELECT DISTINCT(`Trend`) AS `Trend` FROM `%s` ORDER BY `Trend` DESC"%(table_name)

cursor.execute(sql)

connection.commit()
except Exception as e:
print e
finally:
connection.close()

希望这有帮助。

关于python - PyMySQL 在 Python 中将变量分配给表名,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42264991/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com