Django migrations 脚本:
- 项目设计的时候 migrations 脚本和 数据库的表结构是完全对应的
- 通过 SQL 修改数据库表结构,比如 gender —> genderrr
- 在 model 中增加相应的列: 增加 addr 列,
- 执行 makemigrations 和 migrate 命令,发现居然能执行成功;到数据库表执行 show create table xxx 发现增加列成功了。
- 也就是说到此数据库中表的列名是 genderrr 而 model 中依然是 gender, 这居然是可以的
当然如果在 model 中修改的是 gender 的数据类型,在执行 migrate 命令时肯定是会报错的 “Unknown column ‘gender’ in ‘worker’”
说明了:当修改模板文件后,
执行 makemigrations 时 ,Django框架会根据已有的 migrations 脚本,生成新的 migrations 脚本
执行 migrate 时,Django框架会根据上面生成的新的 migrations 生成对应的 SQL 去数据库里执行