ForeignKey ManyToManyField 中related_name使用 及models 中clean方法


 1 # -*- coding:utf-8 -*-
 2 from django.db import models
 3 from django.contrib.auth.models import User
 4 from django.core.exceptions import ValidationError
 5 # Create your models here.
 6 
 7 class UserProfile(models.Model):
 8     user = models.OneToOneField(User,unique=True)
 9     name = models.CharField(max_length=32,verbose_name=u'昵称')
10     age = models.SmallIntegerField(verbose_name=u'年龄',default=0)
11     sex_type = {(0,u''),
12                 (1,u'')
13                 }
14     sex =models.IntegerField(choices=sex_type,default=0,)
15     signature = models.CharField(max_length=128,verbose_name=u'个性签名',blank=True,null=True)
16     def __str__(self):
17         return self.name
18 
19 class Article(models.Model):
20     title = models.CharField(max_length=255,verbose_name=u'标题')
21     content = models.TextField(verbose_name=u'内容')
22     author = models.ForeignKey("UserProfile",verbose_name=u'作者')
23     published_data = models.DateTimeField(auto_now_add= True,verbose_name=u'发布时间')
24     modify_data = models.DateTimeField(auto_now = True,verbose_name=u'更新时间')
25     art_img = models.ImageField(width_field=150,height_field=150,upload_to="uploads",blank=True,null=True)
26     category = models.ForeignKey("Category",verbose_name=u'所属栏目',related_name='myarticle')
27     def __str__(self):
28         return self.title
29 
30 
31 class Category(models.Model):
32     name = models.CharField(max_length=32,verbose_name=u'栏目名称')
33     brief = models.CharField(null=True, blank=True, max_length=255,verbose_name=u'栏目简介')
34     set_as_top_menu = models.BooleanField(default=False)
35     position_index = models.SmallIntegerField()
36     url_name = models.CharField(max_length=32,verbose_name=u'栏目网址')
37     def __str__(self):
38         return self.name
39     class Meta:
40         verbose_name = u'栏目'
41         verbose_name_plural = u'栏目'
42 
43 class Comment(models.Model):
44     content = models.CharField(max_length=255,verbose_name=u'评论内容',blank=True,null=True)
45     author = models.ForeignKey('UserProfile',related_name='mycomment'verbose_name=u'评论人')
46     data = models.DateTimeField(auto_now_add=True,verbose_name=u'评论时间')
47     article = models.ForeignKey("Article",verbose_name=u'所属文章')
48     parent_comment = models.ForeignKey('self',related_name='son_comment',verbose_name=u'上级评论',blank=True,null=True)
49     comment_type_choice = {
50         (0,u'评论'),
51         (1,u'点赞')
52     }
53     comment_type = models.IntegerField(choices=comment_type_choice,default=0,verbose_name=u'评论类型')
54     def __str__(self):
55         return self.content
56     def clean(self):
57         if self.comment_type == 0 and len(self.content)== 0 :
58             raise ValidationError(u'评论不能为空')

ForeignKey ManyToManyField 中 related_name 可加可不加,但是一个字段里有多个ForeignKey 指向同一个字段,则必须添加related_name来区分。以上面代码为例:

在字段里Article里可通过category属性来查询所属栏目:

 article_obj = models.Article.objects.get(id=1) #取id为1的文章

 article_obj.category  查出所属栏目

 but,如何通过栏目来查出这个栏目下所有的文章呢?

 category_obj = models.Category.objects.get(id=1) #取ido为1的栏目

 category_obj.myarticle.all()或者category_obj.myarticle.select_related()来查出栏目1下的所有文章。

,如果Article字段属性category没有添加related_name,可通过model_name+'_set'这种访问方式,使用方法如下:

category_obj.article_set.all()  或者 category_obj.article_set.select_related()

另外 ForeignKey ManyToManyField 对象可以是字段本身,使用方法为:

parent_comment = models.ForeignKey('self',related_name='son_comment',verbose_name=u'上级评论',blank=True,null=True)

 

models中clean方法的使用:

from django.core.exceptions import ValidationError

def clean(self):   if self.comment_type == 0 and len(self.content)== 0 :   raise ValidationError(u'评论不能为空')
这样就规定了如果回复类型是评论的话 必须要有内容 否则后台就会报错。

 

  

 


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM