码迷,mamicode.com
首页 > 其他好文 > 详细

数据查询操作

时间:2017-09-09 16:31:27      阅读:265      评论:0      收藏:0      [点我收藏+]

标签:前端   datetime   comm   tail   hone   blank   分类   []   过滤   

一、模型类

class ArticleManager(models.Manager):
    def archive(self, **kwargs):
        l = []
        month_list = []
        for i in self.filter(**kwargs).values("create_time"):

            date = i[create_time]
            month_list.append(date.month)
            t = date.strftime("%Y-%m-%d")

            if t not in l:
                l.append(t)
        blog_age = str(len(set(month_list))) + "个月"
        return l,blog_age


class UserInfo(AbstractUser):
    """
    用户信息
    """
    nid = models.BigAutoField(primary_key=True)
    nickname = models.CharField(verbose_name=昵称, max_length=32)
    telephone = models.CharField(max_length=11, blank=True, null=True, unique=True, verbose_name=手机号码)
    avatar = models.FileField(verbose_name=头像, upload_to=./upload/avatar/)
    create_time = models.DateTimeField(verbose_name=创建时间, auto_now_add=True)

    fans = models.ManyToManyField(verbose_name=粉丝们,
                                  to=UserInfo,
                                  through=UserFans,

                                  through_fields=(user, follower))

    def __str__(self):
        return self.username


class UserFans(models.Model):
    """
    互粉关系表
    """
    nid = models.AutoField(primary_key=True)
    user = models.ForeignKey(verbose_name=博主, to=UserInfo, to_field=nid, related_name=users)
    follower = models.ForeignKey(verbose_name=粉丝, to=UserInfo, to_field=nid, related_name=followers)

    class Meta:
        unique_together = [
            (user, follower),
        ]


class Blog(models.Model):
    """
    博客信息
    """
    nid = models.BigAutoField(primary_key=True)
    title = models.CharField(verbose_name=个人博客标题, max_length=64)
    site = models.CharField(verbose_name=个人博客后缀, max_length=32, unique=True)
    theme = models.CharField(verbose_name=博客主题, max_length=32)
    user = models.OneToOneField(to=UserInfo, to_field=nid)

    def __str__(self):
        return self.title


class Category(models.Model):
    """
    博主个人文章分类表
    """
    nid = models.AutoField(primary_key=True)
    title = models.CharField(verbose_name=分类标题, max_length=32)

    blog = models.ForeignKey(verbose_name=所属博客, to=Blog, to_field=nid)

    def __str__(self):
        return self.title


class Article(models.Model):
    nid = models.BigAutoField(primary_key=True)
    title = models.CharField(max_length=50, verbose_name=文章标题)
    desc = models.CharField(max_length=255, verbose_name=文章描述)
    read_count = models.IntegerField(default=0)
    comment_count = models.IntegerField(default=0)
    up_count = models.IntegerField(default=0)
    down_count = models.IntegerField(default=0)
    category = models.ForeignKey(verbose_name=文章类型, to=Category, to_field=nid, null=True)
    create_time = models.DateTimeField(verbose_name=创建时间, auto_now_add=True)
    blog = models.ForeignKey(verbose_name=所属博客, to=Blog, to_field=nid)
    tags = models.ManyToManyField(
        to="Tag",
        through=Article2Tag,
        through_fields=(article, tag),
    )

    type_choices = [
        (1, "Python"),
        (2, "Linux"),
        (3, "OpenStack"),
        (4, "GoLang"),
    ]

    article_type_id = models.IntegerField(choices=type_choices, default=None)
    objects = ArticleManager()

    def __str__(self):
        return self.title


#
class ArticleDetail(models.Model):
    """
    文章详细表
    """
    nid = models.AutoField(primary_key=True)
    content = models.TextField(verbose_name=文章内容, )

    article = models.OneToOneField(verbose_name=所属文章, to=Article, to_field=nid)

    def __str__(self):
        return self.article.title


class Comment(models.Model):
    """
    评论表
    """
    nid = models.BigAutoField(primary_key=True)
    article = models.ForeignKey(verbose_name=评论文章, to=Article, to_field=nid)
    content = models.CharField(verbose_name=评论内容, max_length=255)
    create_time = models.DateTimeField(verbose_name=创建时间, auto_now_add=True)

    parent_id = models.ForeignKey(self, blank=True, null=True, verbose_name=父级评论)
    user = models.ForeignKey(verbose_name=评论者, to=UserInfo, to_field=nid)

    up_count = models.IntegerField(default=0)


class ArticleUpDown(models.Model):
    """
    点赞表
    """
    nid = models.AutoField(primary_key=True)
    user = models.ForeignKey(UserInfo, null=True)
    article = models.ForeignKey("Article", null=True)
    UporDown = models.BooleanField(verbose_name=是否赞,default=False)


class CommentUp(models.Model):
    """
    点赞表
    """
    nid = models.AutoField(primary_key=True)
    user = models.ForeignKey(UserInfo, null=True)
    comment = models.ForeignKey("Comment", null=True)


class Tag(models.Model):
    nid = models.AutoField(primary_key=True)
    title = models.CharField(verbose_name=标签名称, max_length=32)
    blog = models.ForeignKey(verbose_name=所属博客, to=Blog, to_field=nid)

    def __str__(self):
        return self.title


class Article2Tag(models.Model):
    nid = models.AutoField(primary_key=True)
    article = models.ForeignKey(verbose_name=文章, to="Article", to_field=nid)
    tag = models.ForeignKey(verbose_name=标签, to="Tag", to_field=nid)

    class Meta:
        unique_together = [
            (article, tag),
        ]

二、数据查询

  前提,前端传来文章的作者名。  

def blog(request, name):
    userinfo = UserInfo.objects.filter(username=name).first()
    if not userinfo:
        return render(request,404.html)
    currentblog = Blog.objects.filter(user=userinfo).first() # 过滤出当前作者的博客  正向查询
    artcle_list = Article.objects.filter(blog=currentblog)  # 查询出该博客所有文章  正向查询
    catagory_list = Category.objects.filter(blog=currentblog) # 查询出该博客所有分类 正常查询  一对多关系

    # 查询所有分类对应文章的数量

    # 方式一
    ret = []
    for catagory in catagory_list:
        tmp = []
        tmp.append(catagory)
        tmp.append(catagory.article_set.all().count())

    # 方式二
    catagory_count = artcle_list.values_list("category__title").annotate(Count("nid")) # 统计每个分类的文章数目,反向查询

    # 标签对应文章的数目
    tag_list = Tag.objects.filter(blog=currentblog)

    # 方式一
    res = []
    for tag in tag_list:
        temp = []
        tmp.append(tag.title)
        tmp.append(artcle_list.filter(tags__title=tag.title).count())
        res.append(tmp)

    # 方式二
    tag_cout = artcle_list.values_list("tags__title").annotate(Count(nid))

    # 文章按时间分类
    ress1,blog_age = Article.objects.archive(blog=currentblog)

    return render(request, homesite.html, {"userinfo": userinfo,catagory_count:catagory_count,
                                             tag_cout:tag_cout,ress1:ress1,blog_age:blog_age,
                                             })

三、前端显示

  后台查询到的数据,通过模板语言渲染后,显示在前端!

数据查询操作

标签:前端   datetime   comm   tail   hone   blank   分类   []   过滤   

原文地址:http://www.cnblogs.com/vipchenwei/p/7498414.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!