一、数据库表设计(models.py文件)
#!/usr/bin/env python
# -*- coding:utf-8 -*-
from __future__ import unicode_literals
from django.db import models
#导入django用户认证表
from django.contrib.auth.models import User
# Create your models here.
class Article(models.Model):#帖子表
title = models.CharField(u"文章标题",max_length=255,unique=True)
categroy = models.ForeignKey("Category",verbose_name=u"板块")
head_img = models.ImageField(upload_to="uploads")#每个帖子都要有一张图片
content = models.TextField(u"文章内容")#帖子内容
author = models.ForeignKey("UserProfile")#一篇文章只能有一个作者
publish_date = models.DateTimeField(auto_now=True)#帖子发布日期
hidden =models.BigAutoField(default=True)#帖子是否显示
priority = models.IntegerField(u"优先级",default=1000)#帖子优先级
def __unicode__(self):#设置默认返回值
return "<%s,author:%s>" %(self.title,self.author)
class Comment(models.Model):#评论表
article = models.ForeignKey("Article")#一条评论只能针对一篇文章
user = models.ForeignKey("UserProfile")#由哪个用户发出评论
#parent_comment = models.ForeignKey('Comment',)#父级评论
parent_comment = models.ForeignKey("self", related_name = 'parcomment',blank=True,null=True)#父级评论
date = models.DateTimeField(auto_now=True)#评论发布日期
comment = models.TextField(max_length=1000)#评论内容
def __unicode__(self):返回默认值
return "<%s,user:%s>" %(self.comment,self.user)
class ThumbUp(models.Model):#点赞统计
article = models.ForeignKey('Article')#点赞的文章
user = models.ForeignKey('UserProfile')#点赞的用户
date = models.DateTimeField(auto_now=True)#人点赞日期
def __unicode__(self):#设置默认返回值
return "<user:%s>" %(self.user)
class Category(models.Model):#板块表
name = models.CharField(max_length=64,unique=True)#板块名字
admin = models.ManyToManyField("UserProfile")#板块管理员多对多,多对多就是双向的一对多
def __unicode__(self):
return self.name
class UserProfile(models.Model):#用户信息表
user = models.OneToOneField(User) #继承系统原生的User表
name = models.CharField(max_length=32)
groups = models.ManyToManyField("UserGroup") #属于哪个用户组
def __unicode__(self):
return self.name
class UserGroup(models.Model):#用户组表
name = models.CharField(max_length=64,unique=True)#用户组名称
def __unicode__(self):
return self.name
二、数据初始化:
settings.py中数据库访问设置
DATABASES = {
'default':{
'ENGINE':'django.db.backends.mysql',
'NAME':'s11bbs',
'HOST':'127.0.0.1',
'USER':'root',
'PASSWORD':'123456',
}
}
在执行同步之前要先创建数据库s11bbs,然后再执行以下语句
python manage.py migrate
mysql> use s11bbs;
Database changed
mysql> show tables;
+----------------------------+
| Tables_in_s11bbs |
+----------------------------+
| auth_group |
| auth_group_permissions |
| auth_permission |
| auth_user |
| auth_user_groups |
| auth_user_user_permissions |
| django_admin_log |
| django_content_type |
| django_migrations |
| django_session |
+----------------------------+
10 rows in set (0.00 sec)
python manage.py migrations
python manage.py migrate
mysql> show tables;
+----------------------------+
| Tables_in_s11bbs |
+----------------------------+
| auth_group |
| auth_group_permissions |
| auth_permission |
| auth_user |
| auth_user_groups |
| auth_user_user_permissions |
| django_admin_log |
| django_content_type |
| django_migrations |
| django_session |
| web_article |
| web_category |
| web_category_admin |
| web_comment |
| web_thumbup |
| web_usergroup |
| web_userprofile |
| web_userprofile_groups |
+----------------------------+
18 rows in set (0.00 sec)
mysql>
三、向admin中注册建立的数据库表
在admin中注册创建的表
from django.contrib import admin
import models
# Register your models here.
admin.site.register(models.Article)
admin.site.register(models.Category)
admin.site.register(models.Comment)
admin.site.register(models.ThumbUp)
admin.site.register(models.UserProfile)
admin.site.register(models.UserGroup)
admin.site.register(models.Article)
创建用户ucode
C:\Users\ryan\PycharmProjects\s11bbs>python manage.py createsuperuser
Username (leave blank to use 'ryan'): ucode
Email address:
Password:
Password (again):
Superuser created successfully.
C:\Users\ryan\PycharmProjects\s11bbs>