我在 Django 中有一个简单的数据模型,其中包含类Department
和Role
. (例如清酒。)
ADepartment
与 具有一对多关系Role
,并且Role
该类包含一个用于标识特定实例的 ID。例如:
> Department: Sales
>> Role (1): Accounts
>> Role (3): Closing
> Department: Maintenance
>> Role (2): IT
>> Role (4): Equipment
这样做的缺点是每个角色都使用自己的全局ID。因此,如果您要创建大量销售角色,然后再创建一个额外的维护角色,那么新的维护角色的 ID 将非常大,并且看起来“不同步”。
因此,我还想为每个角色创建一个特定于部门的 ID,如下所示:
class Role(models.Model):
department_id = models.IntegerField()
缺点是我找不到任何方法:
1) 让现有角色将其现有 ID 转移到新department_id
字段,留下空白但防止未来出现空白:
> Department: Sales
>> Role (1): Accounts
>> Role (3): Closing
>> Role (4): *New Sales Role*
> Department: Maintenance
>> Role (2): IT
>> Role (4): Equipment
>> Role (5): *New Maintenance Role*
2) 或者,动态地将default
值分配给一个方法,该方法扫描表以查找每个部门的所有角色,并为它们分配新的 ID:
> Department: Sales
>> Role (1): Accounts
>> Role (2): Closing
>> Role (3): *New Sales Role*
> Department: Maintenance
>> Role (1): IT
>> Role (2): Equipment
>> Role (3): *New Maintenance Role*
我正在使用 South 来处理模式迁移。