django_model_一对一映射

settings 相关配置

python 复制代码
# settings.py
	...
    DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': 'djangos',
        'USER': 'root',
        'PASSWORD': '990212',
        'HOST': 'localhost',
        'PORT': '33062',
    }
}
bash 复制代码
# 安装数据库驱动
pip install mysqlclient==2.1.1
pip install pymysql
python 复制代码
# 与manage.py同级目录下的__init__.py
import pymysql
pymysql.install_as_MySQLdb()
bash 复制代码
# 数据迁移命令
python manage.py makemigrations appname
python manage.py migrate
bash 复制代码
# 在数据库中 配置好数据表后,逆向生成model
python manage.py inspectdb table1 table2 table3 > appname/models.py

模型关联与映射

  • 一对一映射
  • 一对多映射
  • 多对多映射、多对多自定义中间表
  • 自关联

一对一映射

使用场景

  1. 扩展模型信息
  2. 限制关联模型的数量:确保一个模型只能与另一个模型关联一次

eg:

python 复制代码
class UserProfile(models.Model):
    user = models.OneToOneField(User, on_delete=models.CASCADE())
    bio = models.TextField(blank=True)
    profile_picture = models.ImageField(upload_to="profile_pictures", blank=True)

    def __str__(self):
        return self.user.username


class UserAddress(models.Model):
    user_profile = models.OneToOneField(UserProfile, on_delete=models.CASCADE)
    street_address = models.CharField(max_length=100)
    city = models.CharField(max_length=50)
    state = models.CharField(max_length=50)
    postal_code = models.CharField(max_length=10)

    def __str__(self):
        return f'{self.user_profile.username}\'s address'

扩展了django自带的用户模型

使用 OneToOneField 创建对应关系,在例子中 使用一对一映射,来控制每个用户只能有一个地址。

注意点

  • 参数:on_delete

    • 主对象被删除时,如何处理关联对象。若使用一对一映射则必须指定 on_delete 参数。

    • on_delete=models.CASCADE : 级联删除,关联对象被删除后,其关联字段同时也被删除。

    • on_delete=models.PROTECT:保护关联对象, 当关联对象将被删除时,出发 ProtectedError 异常。

    • on_delete=models.SET_NULL, null=True: 当关联对象被删除时,将关联字段设置为NULL, 前提是该字段允许为空。

    • on_delete=models.setDEFAULT, default=1:当关联对象被删除时,将关联字段设置为其默认值,前提是该字段设置了默认值。

    • on_delete=fun_cname: 在 func_name(instance, **kwargs) 自定义删除操作, instance 表示要删除对象的引用。

      python 复制代码
      def delete_action(instance, other_args):
          ...
      
      
      def pack_delete_action(other_args):
          other_args = ...
      
          return lambda instance: delete_action(instance, other_args)
      
      
      class UserTest(models.Model):
          test_field = models.OneToOneField(User, on_delete=pack_delete_action("some...info.."))

结束

相关推荐
AI小智3 分钟前
为了帮我搞定旅行清单:我的小白老婆报名了30万奖金的黑客松!
后端
双向3313 分钟前
RTX 4090助力深度学习:从PyTorch到生产环境的完整实践指南
后端
shengjk115 分钟前
Java vs Python Web 服务器深度对比:从传统到现代的演进之路
后端
绝无仅有16 分钟前
某辅导教育大厂真实面试过程与经验总结
后端·面试·架构
绝无仅有17 分钟前
Java后端技术面试:银行业技术架构相关问题解答
后端·面试·github
这里有鱼汤24 分钟前
【花姐小课堂】新手也能秒懂!用「风险平价」打造扛造的投资组合
后端·python
CodeSheep28 分钟前
当了leader才发现,大厂最想裁掉的,不是上班总迟到的,也不是下班搞失联的,而是经常把这3句话挂在嘴边的
前端·后端·程序员
shark_chili37 分钟前
Git Worktree:优雅解决多分支开发痛点的终极利器
后端
程序员爱钓鱼1 小时前
Go语言实战案例-项目实战篇:新闻聚合工具
后端·google·go
IT_陈寒1 小时前
Python开发者必须掌握的12个高效数据处理技巧,用过都说香!
前端·人工智能·后端