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模型进行中继,即如何复制它?
如果它不是复合键,它是什么?
这是一个复合主键。尝试执行这个:
show create table mytable;
Run Code Online (Sandbox Code Playgroud)
它应该显示复合键的定义。
从 mysql 的角度来看,这并不是什么“不寻常”的事情。
| 归档时间: |
|
| 查看次数: |
7093 次 |
| 最近记录: |