>데이터 베이스 >MySQL 튜토리얼 >Django 외래 키가 다른 데이터베이스에 걸쳐 있을 수 있나요?

Django 외래 키가 다른 데이터베이스에 걸쳐 있을 수 있나요?

Susan Sarandon
Susan Sarandon원래의
2024-11-02 03:53:301015검색

Can Django Foreign Keys Span Different Databases?

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.