python-在熊猫中进行SQL注入;将列表绑定到SQLAlchemy中的参数

我有这个SQL查询

sql = "select * from table where date in {dl}"

其中dl是日期的元组.我可以通过执行string.format(dl = …)然后在pandas中使用read_sql_query来进行查询,但是我读到这可能导致sql注入,因此并不安全.

但是,sqlAlchemy中似乎没有一个好的替代方法.您似乎无法使用text()将列表传递给参数,然后将列表转换为字符串会首先导致错误.我看到您可以遍历该列表并逐个传递参数,但是为什么有人要这么做呢?

清理变量(删除引号,分号等)是否有助于降低sql注入的风险?无法使用原始sql字符串听起来像是一个可怕的前景.

解决方法:

您可以使用.bindparams()将参数绑定到text()构造中的值:

sql = text("select * from table where date in :dl").bindparams(dl=...)

请注意,传递给dl的值必须是一个元组才能正确呈现.

相关文章

转载:一文讲述Pandas库的数据读取、数据获取、数据拼接、数...
Pandas是一个开源的第三方Python库,从Numpy和Matplotlib的基...
整体流程登录天池在线编程环境导入pandas和xrld操作EXCEL文件...
 一、numpy小结             二、pandas2.1为...
1、时间偏移DateOffset对象DateOffset类似于时间差Timedelta...
1、pandas内置样式空值高亮highlight_null最大最小值高亮背景...