Django 配置多数据库踩的坑,深夜填坑。不管你怎么使用makemigrations和migrate都是No changes detect...
首先是项目setting.py
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.sqlite3',
'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
},
'other': {
'ENGINE': 'django.db.backends.postgresql_psycopg2',
'NAME': 'xxxx', #数据库名字
'USER': 'xxxx', #用户名,数据库的拥有者
'PASSWORD':'xxxx',#登录密码
'HOST':xxxx',#主机地址本地可配置localhost或127.0.0.1。前提是安装postgresql的时候配置pg_hba.conf要配置好。可查看这里。
'PORT':'5432',#可以使用默认端口号
}
}
# 多数据库配置
#就是class的相对路径。项目名/文件夹/db_router.py,db_router.py定义了DatabaseAppsRouter Class
DATABASE_ROUTERS = ['yourProject.yourPath.db_router.DatabaseAppsRouter']
DATABASE_APPS_MAPPING = {
# app : database alis
# 未做指定的app会使用默认数据库
'game' : 'other',
'visitor':'other'
}
接下来就是db_router.py怎么写了。一下方法是自强学堂提供的:
class DatabaseAppsRouter(object):
"""
A router to control all database operations on models for different
databases.
In case an app is not set in settings.DATABASE_APPS_MAPPING, the router
will fallback to the `default` database.
Settings example:
DATABASE_APPS_MAPPING = {'app1': 'db1', 'app2': 'db2'}
"""
def db_for_read(self, model, **hints):
if model._meta.app_label in DATABASE_MAPPING:
return DATABASE_MAPPING[model._meta.app_label]
return None
def db_for_write(self, model, **hints):
if model._meta.app_label in DATABASE_MAPPING:
return DATABASE_MAPPING[model._meta.app_label]
return None
def allow_relation(self, obj_a, obj_b, **hints):
db_obj_a = DATABASE_MAPPING.get(obj_a._meta.app_label)
db_obj_b = DATABASE_MAPPING.get(obj_b._meta.app_label)
if db_obj_a and db_obj_b:
if db_obj_a == db_obj_b:
return True
else:
return False
return None
# for Django 1.4 - Django 1.6
def allow_syncdb(self, db, model):
if db in DATABASE_MAPPING.values():
return DATABASE_MAPPING.get(model._meta.app_label) == db
elif model._meta.app_label in DATABASE_MAPPING:
return False
return None
# Django 1.7 - Django 1.11
def allow_migrate(self, db, app_label, model_name=None, **hints):
if db in DATABASE_MAPPING.values():
return DATABASE_MAPPING.get(app_label) == db
elif app_label in DATABASE_MAPPING:
return False
return None
大概意思就是做个app和数据库的映射。本例中game app和vistor app均映射到数据库other,other是数据库postgresql的别名。其它映射的app全部映射到default,也就是默认数据库sqlite3。
下面是踩坑开始。 写了几个小时的models,大概有十多个数据表,这里不贴代码了。写好执行发现makemigrations和migrate不管怎么执行不报错也不生成数据表。之前以为是误删了数据表只能手动写sql代码去创建数据表了。想想django也是个python web开源的佼佼者了,不该这么弱智。
用一个测试例子演示一下。game app下的model.py
这里定义了两个数据表,games和olgame。网上查阅了好多资料,几乎都是model里定义Meta
class Meta(AbstractGame.Meta):
app_label="other"#指向数据库别名。
按理来说是没有问题,可是使用命令怎么也不能检测到创建的model olgame。有资料说删除app目录下的__pycache__和migrations,确实要删,但是不顶事。
只有games创建成功了。我分析原因可能是abstract=true被OlGame给继承下来了。于是删了AbstractGame.Meta,结果还是一样的。这么多前辈都说是这样的,怎么会错呢。头都大了。冷静想想:因为migrate appname --database alisname执行时会指向指定的数据库。所以Meta下app_label的指向显得有点多余,干脆就删了。如下:
python manage.py makemigrations game #game是app name
成了!!!执行python manage.py migrate game --database other,表创建成功:
小结:
如果自己的model增删改了发现makemigrations和migrate出现这个No changes detected in app 'xxxxx',那么要从两方面去考虑这个问题:
第一,多数据库是否配置有问题,写一个最简单的model测试一下即可。如果没问题那么就是model写的有问题。
第二,就是model写的有问题,如果是继承类model的话一定要小心Meta的使用了。
当然问题都不是绝对的。有可能是环境和版本的问题,本例使用python3.6.5,django2.0.4,postgresql 10.4,sqlite3。

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
-
上一篇
java POI操作execel导出
最近项目当中在使用POI将数据填充置row和cell等行和列,最后导出成execel到前端。一开始使用的方式是一个个去赋值,但是这样做有点麻烦,代码也有点长,不太好维护。于是换了种方案,先导入固定模板,然后将要添加数据的那部分动态添加过去并且进行填充,这样做的好处有利于后期的维护和可扩展,模板可以随时换。在这过程中也学到了不少POI方面的知识。下面总结一下. HSSFWorkbook与xssfworkbook的区别:前者只支持xls(2003)的表格,后者支持xlsx(2007)的表格 我这里主要介绍HSSFWorkbook, 以下是HSSFWorkBook常用代码 Workbook workBook=new HSSFWorkbook();//工作簿 定义一个新工作簿 Sheet sheet = workBook.createSheet("第一个sheet页"); //工作表 表创建一个sheet工作表 Row row = sheet.createRow(0); //行 下标从0开始,0代表创建第一行,1代表创建第二行 Cell cell = row.createCell(0); //...
-
下一篇
解决Android Studio运行时报Error:java.lang.NullPointerException (no error mes...
原文: 解决Android Studio运行时报Error:java.lang.NullPointerException (no error message)错误 今天遇到一个问题,电脑突然关机了,然后重启电脑打开Android studio时,运行程序跑不起来,然后报 Gradle tasks Error: Error:java.lang.NullPointerException (no error message)错误, 然后我clean,rebuild的都没有用。 最后解决方案: 删除工程目录下.gradle文件,重启Android Studio就OK了,删除.gradle文件,不是删除Build.gradle文件。
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- SpringBoot2整合Redis,开启缓存,提高访问速度
- SpringBoot2整合MyBatis,连接MySql数据库做增删改查操作
- SpringBoot2整合Thymeleaf,官方推荐html解决方案
- SpringBoot2初体验,简单认识spring boot2并且搭建基础工程
- Docker快速安装Oracle11G,搭建oracle11g学习环境
- Dcoker安装(在线仓库),最新的服务器搭配容器使用
- SpringBoot2配置默认Tomcat设置,开启更多高级功能
- Docker使用Oracle官方镜像安装(12C,18C,19C)
- SpringBoot2全家桶,快速入门学习开发网站教程
- CentOS7,8上快速安装Gitea,搭建Git服务器