python mysql中in参数化说明

作者:songbaiyiran 时间:2024-01-13 08:38:02 

第一种:拼接字符串,可以解决问题,但是为了避免sql注入,不建议这样写

还是看看第二种:使用.format()函数,很多时候我都是使用这个函数来对sql参数化的

举个例子:

select * from XX where id in (1,2,3)

参数化in里面的值:

select * from XX where id in ({}).format('1,2,3')

你可以打印下看看,和你原来的sql是一模一样的

补充知识:python与mysql交互/读取本地配置文件/交互报错

如果自己写mysql连接要读取本地配置文件,需要注意:

在配置文件config.ini中写:

[sql]
ip = xxx
port = xxx
table = xxx
uname = xxx
passwd = xxx

如:test.py文件


# 首先导入
import pymysql
# 这是获取配置文件的内容
host = conf.get('sql', 'ip')
port = conf.get('sql', 'port')
database = conf.get('sql', 'table'),
user = conf.get('sql', 'uname')
password = conf.get('sql', 'passwd')

# 建立mysql数据库连接

conn = pymysql.connect(host=host, port=port, db=database, user=user, password=password, charset='utf8') # 这里注意有可能报错,后面会说
sql = 'xxx' # sql语句
cs1 = conn.cursor() # 创建执行对象
count = cs1.execute(sql) # 执行sql语句,返回值是数据库中影响的行数,并赋值给count
conn.commit() # 提交数据库的变更
cs1.close() # 关闭执行对象
conn.close() # 关闭数据库连接对象

报错:

can only concatenate tuple (not "bytes") to tuple

这是因为在配置文件读进来的某个结果是个数组,打印看一下就知道了

但是在上篇python读取配置文件中,试过第一个[global]中读取的没有出现数组形式,这个是为什么我也不知道了,欢迎大家留言共同交流

[Errno 11004] getaddrinfo failed 和下面这个

django操作mysql时django.db.utils.OperationalError: (2003, "Can't connect to MySQL server")错误:

如果是在引用本地配置文件时报错,这个报错也很有可能是读取配置文件时的问题

可以尝试这样解决:

1.自己本地用工具也好,命令也好尝试连接一下,如果不行,那就可能是网络或者权限问题

2.如果上面可以,直接写一个独立的python文件,不去读取本地文件,将信息直接写在py文件中,运行结果可以,就是配置文件读取的问题

3.然后尝试读取,并打印读取结果,就能发现问题了

来源:https://blog.csdn.net/songbaiyiran/article/details/78328385

标签:python,mysql,in,参数化
0
投稿

猜你喜欢

  • Tensorflow的可视化工具Tensorboard的初步使用详解

    2021-06-12 18:32:06
  • tensorflow训练中出现nan问题的解决

    2023-02-10 09:34:09
  • pytorch制作自己的LMDB数据操作示例

    2023-05-24 11:51:27
  • 浅析Go汇编语法和MatrixOne使用介绍

    2023-07-13 19:38:18
  • Goland 的安装及激活教程(window、linux下安装)

    2024-05-08 10:51:51
  • Rel与CSS的联合使用

    2010-02-20 13:03:00
  • mysql 修改用户密码图文介绍

    2024-01-21 13:39:51
  • asp.net连接数据库读取数据示例分享

    2024-01-23 11:45:19
  • Python垃圾回收机制三种实现方法

    2023-02-22 00:24:42
  • 3行Python代码实现图像照片抠图和换底色的方法

    2021-12-11 04:57:35
  • c++与python实现二分查找的原理及实现

    2021-11-23 21:09:06
  • python glom模块的使用简介

    2021-08-21 10:22:02
  • Mysql入门系列:MYSQL日志文件维护

    2008-11-24 13:10:00
  • Python实现图片格式转换

    2023-08-03 04:58:57
  • 在Django model中设置多个字段联合唯一约束的实例

    2021-02-09 22:04:59
  • golang 并发编程之生产者消费者详解

    2024-04-28 10:49:32
  • 通过按钮实时切换CSS样式 实现CSS换肤的实例

    2008-07-17 12:55:00
  • SQLServer存储过程中事务的使用方法

    2024-01-29 06:56:03
  • 删除pandas中产生Unnamed:0列的操作

    2021-07-27 03:12:03
  • 在ASP中使用SQL语句之8:随机数的用法

    2007-08-11 13:15:00
  • asp之家 网络编程 m.aspxhome.com