django sqlite升级mysql数据迁移方法(django自带)


  1. django 项目提供了一个导出的方法 python manage.py dumpdata, 不指定 appname 时默认为导出所有的app
    python manage.py dumpdata [appname] > appname_data.json
    
    比如我们有一个项目叫 mysite, 里面有一个 app 叫 blog ,我们想导出 blog 的所有数据
    python manage.py dumpdata blog > blog_dump.json
    
    整库迁移
    python manage.py dumpdata > blog_dump.json
    
  2. 数据导入,不需要指定 appname
    python manage.py loaddata blog_dump.json
    
    备注:一些常用的
    python manage.py dumpdata auth > auth.json # 导出用户数据
    
    优点:可以兼容各种支持的数据库,也就是说,以前用的是 SQLite3,可以导出后,用这种方法导入到 MySQL, PostgreSQL等数据库,反过来也可以。

缺点:数据量大的时候,速度相对较慢,表的关系比较复杂的时候可以导入不成功。