집 >데이터 베이스 >MySQL 튜토리얼 >Django 외래 키가 다른 데이터베이스에 걸쳐 있을 수 있나요?
Django 외래 키의 데이터베이스 간 제한
Django에서는 다양한 모델에 대해 서로 다른 데이터베이스를 사용할 수 있지만 데이터베이스 간 관계 제한되어 있습니다. 이는 라우터를 사용하여 모델을 분할할 때 외래 키 관계가 여러 데이터베이스에 걸쳐 있을 수 없음을 의미합니다.
제공된 예를 고려하십시오.
<code class="python">class LinkModel(models.Model): # in 'urls' database ... class NewsModel(models.Model): # in default database ... link = models.ForeignKey(LinkModel) ...</code>
이 시나리오에서는 할당을 시도할 때 오류가 발생합니다. URL 데이터베이스의 LinkModel 인스턴스를 NewsModel의 링크 필드로:
<code class="python">newsItem, created = NewsModel.objects.get_or_create( title="test" ) link = LinkModel.objects.using('urls').get( id=1 ) newsItem.link = link # error!</code>
Django 제한 사항
Django의 현재 제한 사항으로 인해 데이터베이스 간 외래 키 및 다대다 연결이 방지됩니다. 많은 관계. 이는 데이터베이스 파티셔닝을 사용할 때 이러한 관계가 단일 데이터베이스 내에서 정의되어야 하기 때문입니다.
문제 해결 및 솔루션
Django ForeignKey() 클래스에 알려진 문제가 있습니다. , 특히 유효성 검사() 메서드에서. 이 문제는 버전 1.2, 1.3 및 1.4rc1에서 발생합니다.
이 문제를 해결하기 위한 패치가 제공됩니다. 패치를 적용하면 오류가 해결되고 다른 데이터베이스의 LinkModel 인스턴스를 NewsModel의 링크 필드에 할당할 수 있습니다.
위 내용은 Django 외래 키가 다른 데이터베이스에 걸쳐 있을 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!