原数据库的数据表Article:
class Article(models.Model):
STATUS_CHOICES=(('1','draft'),
('2','publish'))
title = models.CharField(max_length=150)#文章的标题,最大长度100
category=models.CharField(max_length=50,blank=True)#文章的分类,blank=True表示允许为空
publish_time=models.DateTimeField(default=timezone.now)
create_time=models.DateTimeField(auto_now_add=True)#文章创建时间,auto_now_add=True表示默认给文章分配时间
status=models.CharField(max_length=10,choices=STATUS_CHOICES,default='draft')
content=models.TextField(blank=True,null=True)#文章内容,当content为空时默认给一个null值
summary = models.CharField(max_length=200, blank=True)
objects = models.Manager()
published = PublishedManage()
def __str__(self):#加上str后显示的是标题,否则默认显示的是Article对象
return self.title
class Meta: #文章排序
ordering=['-create_time']#按时间倒序排序!
现在要添加一个新的分类:categoryNew
表结构修改后,原来表中已存在的数据,就会出现结构混乱,makemigrations更新表的时候就会出错
解决方法:
1、新增加的字段,设置允许为空。生成表的时候,之前数据新增加的字段就会为空。(null=True允许数据库中为空,blank=True允许admin后台中为空)
犯的错误:没有设置 null=True,black=True
执行>python manage.py migrate时,出现以下错误:
因为数据库中原来的数据是没有 categoryNew这个属性的,所以新增后一定要把它设置为:可以为空!!(null=True,blank=True)
添加代码:
categoryNew=models.ForeignKey(Category,models.CASCADE, related_name='post_category',null=True,blank=True)
class Article(models.Model):
STATUS_CHOICES=(('1','draft'),
('2','publish'))
title = models.CharField(max_length=150)#文章的标题,最大长度100
category=models.CharField(max_length=50,blank=True)#文章的分类,blank=True表示允许为空
# category = models.ForeignKey(Category,models.CASCADE, related_name='post_category')-->会出错!!
categoryNew=models.ForeignKey(Category,models.CASCADE, related_name='post_category',null=True,blank=True)
publish_time=models.DateTimeField(default=timezone.now)
create_time=models.DateTimeField(auto_now_add=True)#文章创建时间,auto_now_add=True表示默认给文章分配时间
status=models.CharField(max_length=10,choices=STATUS_CHOICES,default='draft')
content=models.TextField(blank=True,null=True)#文章内容,当content为空时默认给一个null值
summary = models.CharField(max_length=200, blank=True)
objects = models.Manager()
published = PublishedManage()
def __str__(self):#加上str后显示的是标题,否则默认显示的是Article对象
return self.title
class Meta: #文章排序
ordering=['-create_time']#按时间倒序排序!
然后我们就可以在Admin中看到多了categoryNew了!,就算原来已有的文章中也会多出这个选项^-^!