django遇到TypeError: can't multiply sequence by non-int of type 'tuple'

大家都知道Django默认的数据库用的是sqlite,是的,sqlite用着用着也没什么问题。But,我一次性插入2000条不到的数据竟然花了将近10秒的时间,这怎么能忍呢,于是果断换成了mysql。

人生路漫漫,想转成mysql也不是这么容易的,不转不知道,一转遇到了一大堆问题。现在我分享一个解决了很久的问题。

Django官方的库只支持python2.x版本的mysql驱动,想在windows上用python3+mysql就只能用mysql官方的python驱动。最新支持到python3.4。(注:如果是linux系统,可以尝试mysqlient,Django说可以支持python3,但是windows上装不了这个软件)
转成mysql后,我们首先得执行

python manage.py makemigrations

python manage.py migrate

这两句来同步数据库。当执行到最后这一句的时候,遇到了

TypeError: can't multiply sequence by non-int of type 'tuple'

好吧,这里,我试了N种办法,都没有解决,最后没办法,只能修改一下mysql驱动源码了。找到mysql驱动的安装位置里的一个叫做operations.py的文件。比如我的目录是这样的:E:\Python34\Lib\site-packages\mysql\connector\django,如下图这个文件:
这里写图片描述
打开,查找里面一个叫做bulk_insert_sql的方法,将其修改为如下:

    def bulk_insert_sql(self, fields, num_values):
        # items_sql = "({0})".format(", ".join(["%s"] * len(fields)))
        # return "VALUES " + ", ".join([items_sql] * num_values)
        placeholder_rows_sql = (", ".join(row) for row in num_values)
        values_sql = ", ".join("(%s)" % sql for sql in placeholder_rows_sql)
        return "VALUES " + values_sql

再重新运行,问题消失!

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值