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

来源:互联网 发布:数控旋压机编程 编辑:程序博客网 时间:2024/06/04 18:03

大家都知道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 0
原创粉丝点击