MySQL数据库中指定的两个主键

msh*_*ren 6 mysql django primary-key models

我正在尝试创建一个测试数据库,它是预先存在的数据库的副本.我正在使用Django模型(理论上与原始数据库一起使用的模型)来执行此操作.我最近继承了其他人的代码,并试图弄清楚代码到底发生了什么.

在模型中,表中的一个表有两列标识为主键.

        column1 = models.IntegerField(primary_key = True)
        column2 = models.IntegerField(primary_key = True)
        column3 = models.CharField(max_length = 30)
Run Code Online (Sandbox Code Playgroud)

当我尝试将此模型同步到测试数据库时 - 发生错误:

文件"/somePathHere/MySQLdb/connections.py",第36行,在defaulterrorhandler中引发错误类,errorvalue _mysql_exceptions.OperationalError:(1068,'多个主键定义')

它是在django文档中写的,Django不允许多个主键.但是,看看DESCRIBE [tablename]原始MySQL数据库中的输出,看起来这正是这里发生的事情:

        +------------+------------+------+-----+---------+-------+
        | Field      | Type       | Null | Key | Default | Extra |
        +------------+------------+------+-----+---------+-------+
        | IDENTIFIER | bigint(20) | NO   | PRI | NULL    |       |
        | TIMESTAMP_ | bigint(20) | NO   | PRI | NULL    |       |
        | VALUE_     | longtext   | YES  |     | NULL    |       |
        +------------+------------+------+-----+---------+-------+
Run Code Online (Sandbox Code Playgroud)

请注意,IDENTIFIER和TIMESTAMP_都列为主键.

我在SO(示例1, 示例2示例3)上看到很多关于基于多列创建主键的主题 - 我看到的是复合键吗?在这种情况下,如何通过Django模型进行中继,即如何复制它?

如果它不是复合键,它是什么?

Boh*_*ian 2

这是一个复合主键。尝试执行这个:

show create table mytable;
Run Code Online (Sandbox Code Playgroud)

它应该显示复合键的定义。

从 mysql 的角度来看,这并不是什么“不寻常”的事情。