【python】【sql】格式化注意事项

如果需要格式化表名到 sql 语句,sql 引擎是不支持的。

所以表名需要用字符串格式化,但其他参数最好用 sql 自带的格式,这样就不用去调一些细节,比如字符串的值是否要带引号之类的。

比如:

python 复制代码
cur.execute('SELECT {0} FROM {1} WHERE {2}="{3}"'.format(columnName, tableName, columnName, value))

# 上述是字符串格式化,所以参数 {3},如果是字符串,还要显式指定 ""

优化的方案是:

python 复制代码
cur.execute(f'SELECT ? FROM {tableName} WHERE ?=?', [columnName, columnName, value])

# 或者
cur.execute(F'SELECT ? FROM {tableName} WHERE ?=?', [columnName, columnName, value])

# 其中:
# f 和 F 是 python 格式化字符串的方法(python 3.6及以上提供)
相关推荐
yxc_inspire几秒前
大二 Java 后端学习记录:集合框架(List/Queue/Map/Set)+ 泛型 + 迭代器
java·开发语言
多恩Stone几秒前
【SLURM 入门】sbatch 等概念与常用命令
人工智能·python
全栈凯哥1 分钟前
09.Python 中元组完全指南
python
小二·2 分钟前
Go 语言系统编程与云原生开发实战(第40篇 · 终章)
开发语言·云原生·golang
AsDuang2 分钟前
Python 3.12 MagicMethods - 39 - __mod__
开发语言·python
JuneXcy2 分钟前
第5讲 MySql数据操纵语句--复杂查询
数据库·sql·mysql
小鸡吃米…3 分钟前
Python 中的并发 —— 简介
服务器·数据库·python
格林威3 分钟前
工业相机图像高速存储(C++版):内存映射文件(MMF)零拷贝方案,附海康相机实战代码!
开发语言·c++·数码相机·计算机视觉·视觉检测·工业相机·海康相机
无限进步_4 分钟前
深入解析string:从设计思想到完整实现
开发语言·c++·ide·windows·git·github·visual studio
melonbo5 分钟前
C++ 中用于模块间通信的设计模式
开发语言·c++·设计模式