django에서 모델 구현시 ForeignKeyField를 사용할 일이 매우 많은데 DB상에서 참조무결성을 유지하기위하여 ForeignKeyField가 바라보는 값이 삭제될 때 어떻게 처리해줄지 미리 옵션으로 줄 수 있다.
1. CASCADE
ForeignKeyField가 바라보는 값이 삭제될 때 ForeignKeyField를 포함하는 모델 인스턴스(row)도 삭제된다.
from django.db import models
class TestModel(models.Model): pass
class FKModel(models.Model): test = models.ForeignKeyField(TestModel, on_delete=models.CASCADE) # skip`
2. PROTECT
ForeignKeyField가 바라보는 값이 삭제될 때 삭제가 되지않도록 ProtectedError를 발생시킨다.
from django.db import models
class TestModel(models.Model): pass
class FKModel(models.Model): test = models.ForeignKeyField(TestModel, on_delete=models.PROTECT) # skip`
3. SET_NULL
ForeignKeyField가 바라보는 값이 삭제될 때 ForeignKeyField값을 null로 바꾼다. (null=True일 때만 가능)
from django.db import models
class TestModel(models.Model): pass
class FKModel(models.Model): test = models.ForeignKeyField(TestModel, on_delete=models.SET_NULL, null=True) # skip
4. SET_DEFAULT
ForeignKeyField가 바라보는 값이 삭제될 때 ForeignKeyField값을 default 값으로 바꾼다. (default값이 있을 때만 가능)
from django.db import models
class TestModel(models.Model): pass
DEFAULT_TEST_MODEL_PK = 1
class FKModel(models.Model): test = models.ForeignKeyField(TestModel, on_delete=models.SET_DEFAULT,default=DEFAULT_TEST_MODEL_PK) # skip`
5. SET()
ForeignKeyField가 바라보는 값이 삭제될 때 ForeignKeyField값을 SET에 설정된 함수 등에 의해 설정된다.
from django.db import models
class TestModel(models.Model): title = models.CharField(max_length=100) # skip
def set_FK_Model_test(): return TestModel.objects.get(id=1)
class FKModel(models.Model): test = models.ForeignKeyField(TestModel, on_delete=models.SET(set_FK_Model_test)) # skip
6. DO_NOTHING
ForeignKeyField가 바라보는 값이 삭제될 때 아무런 행동을 취하지 않는다. 참조무결성을 해칠 위험이 있다
from django.db import models
class TestModel(models.Model): pass
class FKModel(models.Model): test = models.ForeignKeyField(TestModel, on_delete=modelsDO_NOTHING) # skip`
'Programming > Python' 카테고리의 다른 글
[Django] QuerySet Django order_by 쿼리 세트, 오름차순 및 내림차순 (0) | 2021.08.23 |
---|---|
[python] String Null 값 조건문 (0) | 2021.06.02 |
[Python] Python & Django 현재시간및 특정기준 날짜 구하기 (0) | 2021.04.26 |
[Jupyter] Jupyter MarkDown (0) | 2019.10.25 |
[Jupyter] Notebook 시작 디렉토리 설정하기 (0) | 2019.10.16 |