Skip to Content
เมนู
คุณต้องลงทะเบียนเพื่อโต้ตอบกับคอมมูนิตี้
คำถามนี้ถูกตั้งค่าสถานะ
2 ตอบกลับ
6976 มุมมอง

I have boolean field and i want to make sql constraint that only 1 record in model could have this field checked. how can i do this?

class ProductPricelist(models.Model):
_inherit = 'product.pricelist'

priority = fields.Boolean('Priority')
อวตาร
ละทิ้ง
คำตอบที่ดีที่สุด

Hi, 
Use api.constrains that will check your record before persisting it in the DB. Like this:

@api.constrains('priority')

 def _check_boolean(self):

    // to boost the performance, you search for only one record that is different from the current one which has the        //boolean checked. If found, then raise.

    checked_bool = self.search([('id', '!=', self.id),('priority', '=', True)], limit=1)  

    if self.priority and checked_bool:

        // Means that more than one record has the field checked.     

       raise ValidationError(_("There's already one checked boolean in record '%s'") % checked_bool.name)


Thanks.

อวตาร
ละทิ้ง
คำตอบที่ดีที่สุด

Use the following code

@api.constrains('priority')

 def _check_priority(self):

    if self.priority:

        checked_bool = self.search([('id', '!=', self.id),('priority', '=', True)])  

        if checked_bool:

            raise ValidationError(_("There's already one priority is checked. Reference : %s") % checked_bool[0].name)

อวตาร
ละทิ้ง
Related Posts ตอบกลับ มุมมอง กิจกรรม
9
มี.ค. 16
60834
1
มี.ค. 15
4752
1
มี.ค. 15
5502
2
มี.ค. 15
4522
0
พ.ย. 24
7