5

这是我的第一个数据库 DB1 模型:

     from django.db import models 

     class Company(models.Model): 

          name = models.CharField(max_length=100, null=True)
          address = models.TextField(max_length=200, null=True)
          website = models.CharField(max_length=200, null=True)
          conatct_no = models.CharField(max_length=20, null=True)
          email = models.EmailField(max_length=20, null=True)
          logo = models.FileField(upload_to='logo/', blank=True, null=True)
          created = models.DateTimeField('company created', auto_now_add=True)
          updated = models.DateTimeField('company updated', auto_now=True, null=True)
          def __unicode__(self):  # Python 3: def __str__(self):
                return self.name

第二个数据库 Db2 的模型:

    from django.db import models

    from leavebuddymaster.models import Company

    class Department(models.Model): 
       company = models.ForeignKey(Company)
       department_name = models.CharField(max_length=50, null=True)
       created = models.DateTimeField('department created', auto_now_add=True)
       updated = models.DateTimeField('department updated', auto_now=True, null=True)
       def __unicode__(self):  # Python 3: def __str__(self):
            return self.department_name

现在,当我打开 Department 表时,它给了我一个错误:

      ProgrammingError at /admin/leavebuddyapp/department/
      (1146, "Table 'leavebuddy_master.leavebuddyapp_department' doesn't exist")

我已经为这两个数据库正确地完成了 settings.py 中的所有设置。你能指导我正确的方向吗?提前谢谢。

4

1 回答 1

15

你是对的,Django 目前不支持跨多个数据库的外键关系。来自跨数据库关系 [Edit 2020: Django version bump]

如果您使用路由器将模型分区到不同的数据库,则这些模型定义的任何外键和多对多关系都必须在单个数据库的内部

这是因为参照完整性。为了维护两个对象之间的关系,Django 需要知道相关对象的主键是有效的。如果主键存储在单独的数据库中,则无法轻松评估主键的有效性

我认为您可以尝试的解决方案(尽管它可能会出现其他问题):

from leavebuddymaster.models import Company

class Department(models.Model): 
    company_id = models.IntegerField()
    
    @property
    def company(self):
        return Company.objects.get(pk=self.company_id)

这使您可以Department.company像在示例中通常那样引用。设置它只是一个问题Department.company_id = Company.pk。希望它有所帮助,或者至少激发一个更好的解决方案!

于 2014-04-24T15:46:00.493 回答