I have an outdated database where some table contains a composite primary key. The model that I run with the manage.py inspectdb command is as follows.
class MyTable(models.Model): field1_id = models.IntegerField(db_column='field1id', primary_key=True) is_favorite = models.BooleanField(db_column='isfavorite', default=False, null=False) is_admin = models.BooleanField(db_column='isadmin', default=False, null=False) role = models.IntegerField(default=USER_GUEST, null=False) field2 = models.BooleanField(null=False, default=True) field3 = models.BooleanField(null=False, default=True) is_active = models.BooleanField(db_column='isactive', null=False, default=True) user = models.ForeignKey( CustomUser, models.DO_NOTHING, db_column='userid', primary_key=True) class Meta: managed = False db_table = 'mytable' unique_together = (('user', 'field1_id'),)
I can receive data normally. However, the problem occurs when I want to run the save() command on some instance of the model. The execution of the django request is incorrect. For instance:
>>> from web_services.apps.my_app.models import MyTable >>> g = MyTable.objects.get(field1_id=12) >>> g.is_active = True >>> g.save() >>> connection.queries[-1] {'time': '0.000', 'sql': 'UPDATE `mytable` SET `isfavorite` = 0, `isadmin` = 1, `role` = 3, `field2` = 1, `field3` = 1, `isactive` = 1 WHERE `mytable`.`field1id` = 12'}
But I need:
{'time': '0.000', 'sql': 'UPDATE `mytable` SET `isfavorite` = 0, `isadmin` = 1, `role` = 3, `field2` = 1, `field3` = 1, `isactive` = 1 WHERE `mytable`.`field1id` = 12' AND `mytable`.`userid` = 1'}
Since django does not support a composite primary key, what would be the best solution to solve this problem? Note that this is an outdated database table, and it did not have AutoField .
EDIT: Add obsolete table structure
+------------+------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +------------+------------+------+-----+---------+-------+ | userid | int(11) | NO | PRI | NULL | | | field1id | int(11) | NO | PRI | NULL | | | isfavorite | int(11) | NO | | 0 | | | isadmin | int(11) | NO | | 0 | | | role | int(11) | YES | | NULL | | | field2 | tinyint(1) | NO | | 1 | | | field3 | tinyint(1) | NO | | 1 | | | isactive | tinyint(4) | NO | | 1 | | +------------+------------+------+-----+---------+-------+