首页 > 数据库 > mysql教程 > 如何在 Psycopg2 中安全地传递表名称作为参数?

如何在 Psycopg2 中安全地传递表名称作为参数?

Patricia Arquette
发布: 2025-01-12 11:07:43
原创
603 人浏览过

How Can I Safely Pass Table Names as Parameters in Psycopg2?

在 Psycopg2 中安全地将表名作为参数传递

在 psycopg2 中,强烈建议不要使用字符串连接 ('select %s from %s where...') 将表名作为参数传递,因为它存在安全风险。 相反,请考虑使用更安全的 psycopg2.sql 模块。

psycopg2 2.7 版本中添加的 sql 模块提供了一种在动态选择表名时动态生成 SQL 查询的方法。以下是一个示例:

<code class="language-python">from psycopg2 import sql

cur.execute(
    sql.SQL("insert into {table} values (%s, %s)").format(table=sql.Identifier('my_table')),
    [10, 20]
)</code>
登录后复制

为了表示表名或字段名,请使用 Identifier 而非 AsIs。出于安全原因,请避免使用 Python 字符串连接或字符串参数插值。

以上是如何在 Psycopg2 中安全地传递表名称作为参数?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板