1 知识点

主要是分析设计数据库的数据表和数据表字段,然后使用Navicat Data Modeler创建模
将sqlite数据库修改成mysql数据库,同步数据

2 模型

2.1 数据表所有的数据列以及其对应的数据类型和约束

  1. nlog_user用户表【id、password(密码)、last_login(上次一登录时间)、is_superuser(是否管理员)、username(用户名)、firstname(姓)、lastname(名)、email(邮箱)、is_staff()、is_active()、date_joined(创建时间)、avatar(头像)、qq(QQ号码)、mobile(手机号码)、url(个人博客地址)】
  2. blog_tag标签表【id、tag(标签名)】
  3. blog_category分类表【id、name(分类名称)、index(分类排序)】
  4. blog_article文章表【id、title(文章标题)、desc(文章描述)、content(文章内容)、ckick_count(点击次数)、is_recommend(是否推荐)、date_publish(发布时间)、user(用户)、category(分类)、tag(标签)】
  5. blog_comment评论表【id、content(评论内容)、username(用户名)、email(邮箱地址)、url(个人网页地址)、date_publish(发布时间)、user(用户)、article(文章)、pid(父级评论)】
  6. blog_links友情链接【id、title(标题)、description(友情链接描述)、callback_url(url地址)、date_publish(发布时间)、index(排列顺序)】
  7. blog_ad广告【id、title(广告标题)、description(广告描述)、image_url(图片路径)、callback_url(回调url)、date_publish(发布时间)、index(排列顺序)】

2.2 设计数据模型图

  • 红色部分需要写Moudels设计生成
  • 绿色部分继承AbstractUser生成
  • 其中橙色blog_article_tag由多对多生成
 
Navicat Data Modeler

3 Models设计

3.1 数据库修改

将sqlite修改成mysql【settings.py】

# DATABASES = {
# 'default': {
# 'ENGINE': 'django.db.backends.sqlite3',
# 'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
# }
# } # 将数据库改成mysql数据库
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME': 'blogdb',
'USER': 'root',
'PASSWORD': 'root',
# 'HOST': '',
# 'PORT': '',
}
}

由于本地环境问题,Python_mysql无法安装,所以使用pymysql【__init__.py】

import pymysql

pymysql.install_as_MySQLdb()

3.2 创建Models

根据自己设计的模型,创建相关的Model【Models.py】

# coding: utf-8
# author: spareribs from django.db import models from django.contrib.auth.models import AbstractUser # Create your models here. '''
############ 本地模型用到的字段类型和和参数的含义 max_length:最大长度
blank:True可以为空
null:可以为null
verbose_name:admin显示名称
default:默认值
unique:True表示唯一
【ImageField】:upload_to表示MEDIA_ROOT的子目录,用来存放上传的文件
【CharField】
【URLField】
【IntegerField】
【DateTimeField】:auto_now_add表示自动设置当前时间
【TextField】
【BooleanField】
【EmailField】
'''
# 用户(User)模型
# 采用的继承方式扩展用户信息
class User(AbstractUser):
# 在继承的基础上新增4个字段
avatar = models.ImageField(upload_to='avatar/%Y/%m', default='avatar/default.png', max_length=200, blank=True,
null=True, verbose_name='用户头像')
qq = models.CharField(max_length=20, blank=True, null=True, verbose_name='QQ号码')
mobile = models.CharField(max_length=11, blank=True, null=True, unique=True, verbose_name='手机号码')
url = models.URLField(max_length=100, blank=True, null=True, verbose_name='个人网页地址') # 使用内部的class Meta 定义模型的元数据
class Meta:
# verbose_name:数据库表名名称,这里表名称为“用户”
verbose_name = '用户'
# verbose_name_plural:人类可读的单复数名称,这里“用户”复数名称为“用户”
verbose_name_plural = verbose_name
# ordering:如排序选项,这里以id降序来排序
ordering = ['-id'] # 对象的字符串表达式(unicode格式)
def __unicode__(self):
return self.username # 标签(tag)模型
class Tag(models.Model):
name = models.CharField(max_length=30, verbose_name='标签名称') class Meta:
verbose_name = '标签'
verbose_name_plural = verbose_name def __unicode__(self):
return self.name # 分类(category)模型
class Category(models.Model):
name = models.CharField(max_length=30, verbose_name='分类名称')
index = models.IntegerField(default=999, verbose_name='分类的排序') class Meta:
verbose_name = '分类'
verbose_name_plural = verbose_name
ordering = ['index', 'id'] def __unicode__(self):
return self.name # 自定义一个文章Model的管理器
# 1、新加一个数据处理的方法
# 2、改变原有的queryset
class ArticleManager(models.Manager):
def distinct_date(self):
distinct_date_list = []
date_list = self.values('date_publish')
for date in date_list:
date = date['date_publish'].strftime('%Y/%m文章存档')
if date not in distinct_date_list:
distinct_date_list.append(date)
return distinct_date_list # 文章(aticle)模型
class Article(models.Model):
title = models.CharField(max_length=50, verbose_name='文章标题')
desc = models.CharField(max_length=50, verbose_name='文章描述')
content = models.TextField(verbose_name='文章内容')
click_count = models.IntegerField(default=0, verbose_name='点击次数')
is_recommend = models.BooleanField(default=False, verbose_name='是否推荐')
date_publish = models.DateTimeField(auto_now_add=True, verbose_name='发布时间') #
user = models.ForeignKey(User, verbose_name='用户')
category = models.ForeignKey(Category, blank=True, null=True, verbose_name='分类')
tag = models.ManyToManyField(Tag, verbose_name='标签') objects = ArticleManager() class Meta:
verbose_name = '文章'
verbose_name_plural = verbose_name
ordering = ['-date_publish'] def __unicode__(self):
return self.title # 评论(comment)模型
class Comment(models.Model):
content = models.TextField(verbose_name='评论内容')
username = models.CharField(max_length=30, blank=True, null=True, verbose_name='用户名')
email = models.EmailField(max_length=50, blank=True, null=True, verbose_name='邮箱地址')
url = models.URLField(max_length=100, blank=True, null=True, verbose_name='个人网页地址')
date_publish = models.DateTimeField(auto_now_add=True, verbose_name='发布时间')
#
user = models.ForeignKey(User, blank=True, null=True, verbose_name='用户')
article = models.ForeignKey(Article, blank=True, null=True, verbose_name='文章')
pid = models.ForeignKey('self', blank=True, null=True, verbose_name='父级评论') class Meta:
verbose_name = '评论'
verbose_name_plural = verbose_name def __unicode__(self):
return str(self.id) # 友情链接(links)模型
class Links(models.Model):
title = models.CharField(max_length=50, verbose_name='标题')
description = models.CharField(max_length=200, verbose_name='友情链接描述')
callback_url = models.URLField(verbose_name='url地址')
date_publish = models.DateTimeField(auto_now_add=True, verbose_name='发布时间')
index = models.IntegerField(default=999, verbose_name='排列顺序(从小到大)') class Meta:
verbose_name = '友情链接'
verbose_name_plural = verbose_name
ordering = ['index', 'id'] def __unicode__(self):
return self.title # 广告(ad)模型
class Ad(models.Model):
title = models.CharField(max_length=50, verbose_name='广告标题')
description = models.CharField(max_length=200, verbose_name='广告描述')
image_url = models.ImageField(upload_to='ad/%Y/%m', verbose_name='图片路径')
callback_url = models.URLField(null=True, blank=True, verbose_name='回调url')
date_publish = models.DateTimeField(auto_now_add=True, verbose_name='发布时间')
index = models.IntegerField(default=999, verbose_name='排列顺序(从小到大)') class Meta:
verbose_name = u'广告'
verbose_name_plural = verbose_name
ordering = ['index', 'id'] def __unicode__(self):
return self.title

使用用户自定义的User Model【settings.py】

# 自定义用户Model
AUTH_USER_MODEL = 'blog.User'

3.3 创建数据库并同步数据表

创建数据库

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

mysql> create database blogdb;
Query OK, 1 row affected (0.00 sec)

同步

(env_py27_django_blog) D:\MaiZi_Edu\Dropbox\Maizi\Django_blog\django_blog>python manage.py makemigrations
2017-01-02 12:41:28,928 [MainThread:1008] [django.db.backends:89] [utils:execute] [DEBUG]- (0.000) SET SQL_AUTO_IS_NULL = 0; args=None
Migrations for 'blog':
0001_initial.py:
- Create model User
- Create model Ad
- Create model Article
- Create model Category
- Create model Comment
- Create model Links
- Create model Tag
- Add field category to article
- Add field tag to article
- Add field user to article (env_py27_django_blog) D:\MaiZi_Edu\Dropbox\Maizi\Django_blog\django_blog>python manage.py migrate
2017-01-02 12:41:35,924 [MainThread:8876] [django.db.backends:89] [utils:execute] [DEBUG]- (0.001) SET SQL_AUTO_IS_NULL = 0; args=None
2017-01-02 12:41:35,980 [MainThread:8876] [django.db.backends:89] [utils:execute] [DEBUG]- (0.000) SET SQL_AUTO_IS_NULL = 0; args=None
2017-01-02 12:41:35,986 [MainThread:8876] [django.db.backends:89] [utils:execute] [DEBUG]- (0.001) SHOW FULL TABLES; args=None
2017-01-02 12:41:35,992 [MainThread:8876] [django.db.backends.schema:102] [schema:execute] [DEBUG]- CREATE TABLE `django_migrations` (`id` integer AUTO_INCREMENT NOT NULL PRIMARY KEY, `app` varchar(255) NOT NULL, `name` varchar(255) NOT NULL, `applied` datetime(6) NOT NULL); (params None)
2017-01-02 12:41:36,085 [MainThread:8876] [django.db.backends:89] [utils:execute] [DEBUG]- (0.086) CREATE TABLE `django_migrations` (`id` integer AUTO_INCREMENT NOT NULL PRIMARY KEY, `app` varchar(255) NOT NULL, `name` varchar(255) NOT NULL, `applied` datetime(6) NOT NULL); args=None
2017-01-02 12:41:36,119 [MainThread:8876] [django.db.backends:89] [utils:execute] [DEBUG]- (0.025) SELECT engine FROM information_schema.tables WHERE table_name = 'django_migrations'; args=[u'django_migrations']
2017-01-02 12:41:36,144 [MainThread:8876] [django.db.backends:89] [utils:execute] [DEBUG]- (0.002) SELECT `django_migrations`.`app`, `django_migrations`.`name` FROM `django_migrations`; args=()
...
...
(此处省略很多内容)

查看验证数据库是否已经创建成功

 
Navicat Premium

4 拓展

  • 继承的方式拓展用户信息
  • 关联的方式拓展用户信息

作者:Spareribs
链接:https://www.jianshu.com/p/22d55fe44bdc
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

django数据库设计的更多相关文章

  1. Django数据库设计中字段为空的方式

    今天在做数据库设计的时候,设计了如下User表,其中我把email和phone字段设置为允许为空: class User(models.Model): username = models.CharFi ...

  2. 19 01 15 django 数据库设计模型 管理站点 注意:在引入外键在django 2以上改版

    模型设计 我们之前操作数据库是通过写sql语句  ORM框架    可以通过不写sql  语句来进行操作数据库 1.定义模型类 模型类定义在models.py文件中,继承自models.Model类. ...

  3. 使用django开发博客过程记录1——数据库设计

    1.数据库设计 2.插入测试数据 3.配置相关问题 1.数据库设计 数据库有简单的三张表:Article.Category.Tag以下是代码 # -*- coding:utf-8 -*- from _ ...

  4. Django 博客项目01 数据库设计与验证码校验+Ajax登录

    数据库设计 from django.db import models from django.contrib.auth.models import AbstractUser class UserInf ...

  5. django文件上传、图片验证码、抽屉数据库设计

    1.Django文件上传之Form方式 settings.py, ALLOWED_HOSTS = ['*'] INSTALLED_APPS = [ 'django.contrib.admin', 'd ...

  6. Django 小实例S1 简易学生选课管理系统 1 项目流程梳理与数据库设计

    Django 小实例S1 简易学生选课管理系统 第1章--项目流程梳理与数据库设计 点击查看教程总目录 作者自我介绍:b站小UP主,时常直播编程+红警三,python1对1辅导老师. 1 项目流程梳理 ...

  7. Python之路【第十九章】:Django 数据库对象关系映射

    Django ORM基本配置 到目前为止,当我们的程序涉及到数据库相关操作时,我们一般都会这么搞: 创建数据库,设计表结构和字段 使用 MySQLdb 来连接数据库,并编写数据访问层代码 业务逻辑层去 ...

  8. CMDB数据库设计

    title: CMDB 数据库设计 tags: Django --- CMDB数据库设计 具体的资产 服务器表和网卡.内存.硬盘是一对多的关系,一个服务器可以有多个网卡.多个内存.多个硬盘 hostn ...

  9. Django数据库查询优化与AJAX

    目录 数据库设计三大范式 orm相关的数据库查询优化 惰性查询 all.only与defer select_related与prefetch_related MTV与MVC模型 MTV(models ...

随机推荐

  1. Docker背后的内核知识——cgroups资源限制(转)

    时间 2015-04-20 21:10:00 InfoQ 原文  http://www.infoq.com/cn/articles/docker-kernel-knowledge-cgroups-re ...

  2. (十)Unity5.0新特性------新UI系统实战

    原文 Unity New GUI Tutorial – Part 1 Unity New GUI Tutorial- Part 2 Unity New GUI Tutorial – Part 3 大家 ...

  3. linux下各种形式的shell加法操作总结

    linux 下shell加法操作总结: #!/bin/bash   n=1;echo -n "$n "   let "n = $n + 1" echo -n & ...

  4. C#指南,重温基础,展望远方!(4)表达式

    表达式是在操作数和运算符的基础之上构造而成. 表达式的运算符指明了向操作数应用的运算. 运算符的示例包括 +.-.*./ 和 new. 操作数的示例包括文本.字段.局部变量和表达式. 如果表达式包含多 ...

  5. 阅读《Android 从入门到精通》(29)——四大布局

    LinearLayout 类方法 watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQ ...

  6. python 2,3版本自动识别导入

     import sys if str(sys.version[0]) == "3":    from urllib.parse import quote_plus    from  ...

  7. python 实现元组中的的数据按照list排序, python查询mysql得到的数据是元组格式,按照list格式对他们排序

    需求: 需要用echart实现软件模块的统计分析,首先是对数据库的数据查询出来,然后给数据封装成列表(list)格式,数据传到前台,在echart实现绑定数据. 因为数据已经按照从大到小的顺序显示出来 ...

  8. Web前端的状态管理(State Management)

    背景 我相信很多朋友跟我一样,初次听到什么Flux, Redux, Vuex,状态管理的时候是一脸懵逼的.因为在外面之前前端大部分开发的时候,根本没有那么多的概念.自从ReactJS火爆后,什么Flu ...

  9. makefile之short函数

    函数名称:排序函数-$(sort LIST) 函数功能:给字串"LIST"中的单词以首字母为准进行排序(升序),并去掉重复的单词. 返回值:空格分割的没有重复单词的字串. 函数说明 ...

  10. 从Python的角度来看编码与解码

    导语: Python2和Python3中,因为默认字符集的不同而造成的麻烦,简直是程序员的梦魇!要彻底告别这个麻烦,就需要从本质上来理解编码和解码. 为什么要有编码? 对于不会英文的中国人来说,将英文 ...