Warning: file_get_contents(/data/phpspider/zhask/data//catemap/7/elixir/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Python django模型外键创建索引_Python_Sql_Django_Models - Fatal编程技术网

Python django模型外键创建索引

Python django模型外键创建索引,python,sql,django,models,Python,Sql,Django,Models,我正在django创建模型。这是我在模型文件中的配置。我想创建一个引用县和公民的表governmentoffice。然而,当我运行manage.py sqlal时,它更改了我在政府官方表中的列名 class counties(models.Model): name = models.CharField(max_length=50, primary_key=True, unique=True) population = models.IntegerField() gover

我正在django创建模型。这是我在模型文件中的配置。我想创建一个引用县和公民的表
governmentoffice
。然而,当我运行manage.py sqlal时,它更改了我在政府官方表中的列名

class counties(models.Model):
    name = models.CharField(max_length=50, primary_key=True, unique=True)
    population = models.IntegerField()
    governer = models.CharField(max_length=75)

class citizen(models.Model):
    ssn = models.CharField(max_length=40, primary_key=True)
    citizen_name = models.CharField(max_length=50, unique=True)
    age = models.IntegerField()
    income = models.IntegerField()
    username = models.CharField(max_length=30)
    password = models.CharField(max_length=30)

class governmentOfficial(models.Model):
    countyName = models.ForeignKey(counties, primary_key=True)
    offical_name = models.ForeignKey(citizen, to_field='citizen_name')
    position = models.CharField(max_length=50)
    year_elected = models.IntegerField(max_length=4)
    party = models.CharField(max_length=25)
    county_username=models.CharField(max_length=20)
    county_password=models.CharField(max_length=20)
这是我的sql输出

CREATE TABLE `troywebsite_governmentofficial` (
    `countyName_id` varchar(50) NOT NULL PRIMARY KEY,
    `offical_name_id` varchar(50) NOT NULL,
    `position` varchar(50) NOT NULL,
    `year_elected` integer NOT NULL,
    `party` varchar(25) NOT NULL,
    `county_username` varchar(20) NOT NULL,
    `county_password` varchar(20) NOT NULL
)
;
ALTER TABLE `troywebsite_governmentofficial` ADD CONSTRAINT `countyName_id_refs_name_2c9a2c94` FOREIGN KEY (`countyName_id`) REFERENCES `troywebsite_counties` (`name`);
ALTER TABLE `troywebsite_governmentofficial` ADD CONSTRAINT `offical_name_id_refs_citizen_name_6f795c2a` FOREIGN KEY (`offical_name_id`) REFERENCES `troywebsite_citizen` (`citizen_name`);

CREATE INDEX `troywebsite_governmentofficial_effdd6a5` ON `troywebsite_governmentofficial` (`offical_name_id`);
CREATE INDEX `troywebsite_solider_c5b4e228` ON `troywebsite_solider` (`solider_name_id`);

有没有办法在governmentofficial中取出
创建索引
,并保留
countyName
官方名称
作为列?

您可以使用db\u column参数调用列,无论您喜欢什么


countyName=models.ForeignKey(countries,primary\u key=True,db\u column='which')

是否有任何特殊原因使ID列看起来不像ID列?无特殊原因。我只是想知道为什么django要更改列名,因为列名对代码并不重要。