关于django中model的多字段联合唯一索引

本文介绍如何在Django中使用ORM定义模型,通过设置unique_together参数实现多字段之间的联合唯一约束,确保在数据库层面字段组合的唯一性,避免数据冗余和错误。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

有时候一个表多字段,要实现字段之间两两联合唯一怎么办了?下面就是办法!!!

class UserOrderHouse(models.Model):
    """
    客户预约表
    """
    broker_id = models.ForeignKey(to="Broker", verbose_name="经纪人", null=True, blank=True)
    client_id = models.ForeignKey(to="Client", verbose_name="游客", null=True, blank=True)
    house = models.ForeignKey(to="house.House", verbose_name="楼盘预约", null=True, blank=True)
    rend_house = models.ForeignKey(to="old_house.RentHouse", verbose_name="出租预约", null=True, blank=True)
    sell_house = models.ForeignKey(to="old_house.SellHouse", verbose_name="求租预约", null=True, blank=True)
    buy_house = models.ForeignKey(to="old_house.BuyHouse", verbose_name="求售预约", null=True, blank=True)
    time = models.DateTimeField(auto_now=True, verbose_name="预约时间")

    class Meta:
        unique_together = (
            ('broker_id', 'house'),
            ('broker_id', 'rend_house'),
            ('broker_id', 'sell_house'),
            ('broker_id', 'buy_house'),
            ('client_id', 'house'),
            ('client_id', 'rend_house'),
            ('client_id', 'sell_house'),
            ('client_id', 'buy_house'),
        )
        verbose_name = "用户预约"
        verbose_name_plural = verbose_name
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值