Python中Mysql数据库的sql语句参数传递问题

在Python中, 通过pymysql库连接Mysql数据库的sql语句参数传递时需要注意:

mysql的sql语句的字符串格式化不是标准的python的字符串格式化, 在python中无论字符串,数字或者其他类型, 在sql字符串中都要使用字符串占位符%s , 并且%s不能加引号.

sql语句参数传递方式有如下几种:

一.sql语句直接拼接

tn="co2"

qt =1

val = 2.524

sql = " insert into `mes_realdata` (`TagName`, `Quality`,    `Value`) values   "
        (' ''' + tn+ "', ''''  + qt +"', '" + val +"'' );  "

二.使用参数替代

tn="co2"

qt =1

val = 2.524

sql = " insert into `mes_realdata` (`TagName`, `Quality`,    `Value`) values  (%s,%s,%s); "

sql = sql %(tn, qt, val)

注:如果是单个变量的,使用如下方式:

sql = " insert into `mes_realdata` (`TagName`) values  (%s); "

sql = sql %tn

 三.使用数组的方式

tn="co2"

qt =1

val = 2.524

sql = " insert into `mes_realdata` (`TagName`, `Quality`,    `Value`) values  (%s,%s,%s); "

cursor.execute(sql, [tn, qt, val] )

四.使用字典dict类型传递变量

 sql = ''' insert into `mes_realdata` (`TagName`, `Quality`,  `Value`) values   
        ('%(TagName)s', '%(Quality)s',  '%(Value)s' );  '''

d ={'TagName': 'co2', 'Quality': 1,  'Value': '6.672067'}

cursor.execute( sql %(d) )

 上面这种方法适合字段比较多的时候,字段和值对应顺序不会错.

  • 3
    点赞
  • 29
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值