我正在尝试创建一个测试数据库,它是预先存在的数据库的副本.我正在使用Django模型(理论上与原始数据库一起使用的模型)来执行此操作.我最近继承了其他人的代码,并试图弄清楚代码到底发生了什么.
在模型中,表中的一个表有两列标识为主键.
column1 = models.IntegerField(primary_key = True)
column2 = models.IntegerField(primary_key = True)
column3 = models.CharField(max_length = 30)
当我尝试将此模型同步到测试数据库时 – 发生错误:
File “/somePathHere/MySQLdb/connections.py”, line 36, in defaulterrorhandler raise errorclass, errorvalue
_mysql_exceptions.OperationalError: (1068, ‘Multiple primary key defined’)
在django docs中写的是Django不允许多个主键.但是,查看原始MySQL数据库中DESCRIBE [tablename]的输出,看起来就是这里正在发生的事情:
+------------+------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+------------+------------+------+-----+---------+-------+
| IDENTIFIER | bigint(20) | NO | PRI | NUL