免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3044 | 回复: 4
打印 上一主题 下一主题

on duplicate key update 有问题么? mysqlDB. [复制链接]

论坛徽章:
33
荣誉会员
日期:2011-11-23 16:44:17天秤座
日期:2014-08-26 16:18:20天秤座
日期:2014-08-29 10:12:18丑牛
日期:2014-08-29 16:06:45丑牛
日期:2014-09-03 10:28:58射手座
日期:2014-09-03 16:01:17寅虎
日期:2014-09-11 14:24:21天蝎座
日期:2014-09-17 08:33:55IT运维版块每日发帖之星
日期:2016-04-17 06:23:27操作系统版块每日发帖之星
日期:2016-04-18 06:20:00IT运维版块每日发帖之星
日期:2016-04-24 06:20:0015-16赛季CBA联赛之天津
日期:2016-05-06 12:46:59
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2014-03-27 16:50 |只看该作者 |倒序浏览
  1. Traceback (most recent call last):
  2.   File "/root/bin/traffic.py", line 176, in <module>
  3.     traffic_week(timestamp)
  4.   File "/root/bin/traffic.py", line 156, in traffic_week
  5.     cur.executemany(sql, params)
  6.   File "/usr/lib64/python2.6/site-packages/MySQL_python-1.2.4-py2.6-linux-x86_64.egg/MySQLdb/cursors.py", line 245, in executemany
  7.     self.errorhandler(self, TypeError, msg)
  8.   File "/usr/lib64/python2.6/site-packages/MySQL_python-1.2.4-py2.6-linux-x86_64.egg/MySQLdb/connections.py", line 36, in defaulterrorhandler
  9.     raise errorclass, errorvalue
  10. TypeError: not all arguments converted during string formatting
复制代码
  1.     ## ----------------------------------------------------------------
  2.     sql = """INSERT INTO traffic_hz_week(tr_time, tr_week, tr_hour,
  3.                  tr_min, tr_road, tr_road_level,
  4.                  tr_speed_total, tr_speed_count)
  5.              VALUES(%s, %s, %s, %s, %s, %s, %s, %s)
  6.              ON DUPLICATE KEY UPDATE
  7.                  tr_speed_total = tr_speed_total + %s,
  8.                  tr_speed_count = tr_speed_count + 1
  9.           """
  10.     params = ()

  11.     for d1 in data:
  12.         param = d1 + (d1[6],)
  13.         params = params + ((param),)

  14.     for pa in params:
  15.         print pa

  16.     cur.executemany(sql, params)
复制代码
上面这段代码有问题么? 为啥会报错呢 ...

论坛徽章:
33
荣誉会员
日期:2011-11-23 16:44:17天秤座
日期:2014-08-26 16:18:20天秤座
日期:2014-08-29 10:12:18丑牛
日期:2014-08-29 16:06:45丑牛
日期:2014-09-03 10:28:58射手座
日期:2014-09-03 16:01:17寅虎
日期:2014-09-11 14:24:21天蝎座
日期:2014-09-17 08:33:55IT运维版块每日发帖之星
日期:2016-04-17 06:23:27操作系统版块每日发帖之星
日期:2016-04-18 06:20:00IT运维版块每日发帖之星
日期:2016-04-24 06:20:0015-16赛季CBA联赛之天津
日期:2016-05-06 12:46:59
2 [报告]
发表于 2014-03-28 10:03 |只看该作者
自己顶一下.

论坛徽章:
33
荣誉会员
日期:2011-11-23 16:44:17天秤座
日期:2014-08-26 16:18:20天秤座
日期:2014-08-29 10:12:18丑牛
日期:2014-08-29 16:06:45丑牛
日期:2014-09-03 10:28:58射手座
日期:2014-09-03 16:01:17寅虎
日期:2014-09-11 14:24:21天蝎座
日期:2014-09-17 08:33:55IT运维版块每日发帖之星
日期:2016-04-17 06:23:27操作系统版块每日发帖之星
日期:2016-04-18 06:20:00IT运维版块每日发帖之星
日期:2016-04-24 06:20:0015-16赛季CBA联赛之天津
日期:2016-05-06 12:46:59
3 [报告]
发表于 2014-04-01 07:52 |只看该作者
Day Day Up.

论坛徽章:
11
技术图书徽章
日期:2014-03-01 14:44:34天蝎座
日期:2014-05-21 22:11:59金牛座
日期:2014-05-30 17:06:14
4 [报告]
发表于 2014-04-01 10:51 |只看该作者
没用过MySQLdb,不过接口也是DB-API 2.0,和sqlite3类似。看上去是“?”和传入的params不匹配,改改:
  1. for d1 in data:
  2.         param = d1 + (d1[6],)
  3.         params = params + (param,)
复制代码

论坛徽章:
33
荣誉会员
日期:2011-11-23 16:44:17天秤座
日期:2014-08-26 16:18:20天秤座
日期:2014-08-29 10:12:18丑牛
日期:2014-08-29 16:06:45丑牛
日期:2014-09-03 10:28:58射手座
日期:2014-09-03 16:01:17寅虎
日期:2014-09-11 14:24:21天蝎座
日期:2014-09-17 08:33:55IT运维版块每日发帖之星
日期:2016-04-17 06:23:27操作系统版块每日发帖之星
日期:2016-04-18 06:20:00IT运维版块每日发帖之星
日期:2016-04-24 06:20:0015-16赛季CBA联赛之天津
日期:2016-05-06 12:46:59
5 [报告]
发表于 2014-04-01 10:54 |只看该作者
回复 4# timespace


sqlite 的 api 里说明了,要用 ? 做 占位符, mysqldb 的 文档里说的好象是用 %s, 我等下换换试试.

另外, 报错的不是数量, 直接报语法错误.     
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP