开发者社区> 问答> 正文

python web.py db.update 问题?报错

db.update(table, where='id IN ($id)', vars={'id': id.split(',')})

id值为串"1,2",以上代码报错:

OperationalError: (1241, 'Operand should contain 1 column(s)')

若换成:

db.update(table, where='id IN ($id)', vars={'id': id})

则报:Warning: Truncated incorrect DOUBLE value: '1,2'

莫非对于IN操作只能串拼接,不能参数替换?

展开
收起
爱吃鱼的程序员 2020-06-22 11:04:55 495 0
1 条回答
写回答
取消 提交回答
  • https://developer.aliyun.com/profile/5yerqm5bn5yqg?spm=a2c6h.12873639.0.0.6eae304abcjaIB

    http://ruby-china.org/topics/18429

    db.update 的用法用错了,按照你的代码实现的SQL是这样的:

    updatetablesetwhereidin((1,2))

    正确的用法是这样的:

    db.update(table_name,where='idin$id',column_name='abc',vars={'id':[1,2]})

    生成的SQL:

    updatetable_namesetcolumn_name='abc'whereidin(1,2)




    2020-06-22 11:05:11
    赞同 展开评论 打赏
问答分类:
问答地址:
问答排行榜
最热
最新

相关电子书

更多
From Python Scikit-Learn to Sc 立即下载
Data Pre-Processing in Python: 立即下载
双剑合璧-Python和大数据计算平台的结合 立即下载