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. ASP.NET MVC源码分析系列

    Controller下的JsonResult的ExecuteResult方法 public override void ExecuteResult(ControllerContext context) ...

  2. 07-hibernate注解-一对多(多对一)双向外键关联

    一对多(多对一)双向外键 多方:多方持有一方的引用. @ManyToOne(cascade={CasCadeType.ALL},fetch=FetchType.EAGER) @JoinColumn(n ...

  3. iOS多线程的初步研究(一)-- NSThread

    对于多线程的开发,iOS系统提供了多种不同的接口,先谈谈iOS多线程最基础方面的使用.产生线程的方式姑且分两类,一类是显式调用,另一类是隐式调用. 一.显示调用的类为NSThread.一般构造NSTh ...

  4. Sphinx-简介及原理

    1.Sphinx简介 是一款基于SQL的高性能全文检索引擎(还不支持NoSQL), 主要优点有: 1).创建和重建索引迅速 2).大数据量时检索速度较快 3).为很多脚本语言设计了检索API(如PHP ...

  5. 让网页自动调用双核浏览器的极速模式(<meta name="renderer" content="webkit">)

    背景:最近做了一个网站,传单服务器之后,每次打开都是乱码,不对啊,我在本地测得明明是排版很整齐啊,然后发现,360用的是“兼容模式”打开的,这就尴尬了,用户一打开就是乱码,这用户体验得有多差!用户可不 ...

  6. $("#SpecialAptitude").on("change",function(){CheckType($(this))})$("#SpecialAptitude").on("change",CheckType($(this)))

    $("#SpecialAptitude").on("change",function(){CheckType($(this))})$("#Specia ...

  7. /usr/lib64/libssl.so.10: no version information available (required by ./mongod)

    启动mongodb时,日志提示以下信息: ./mongod: /usr/lib64/libssl.so.10: no version information available (required b ...

  8. git团队协作流程

    创建项目,在github上增加一个repository,在要提交的工程目录下打开git bash,执行git init 命令,用于初始化,可使用git status 查看git状态,然后使用git a ...

  9. Thinkphp+AJAX动态验证用户输入是否合法

    遇到用户注冊等情况时.假设等用户输入全部信息,点击注冊button提交后.再验证输入是否正确,体验非常不好,并且非常浪费用户的时间,添加注冊成本,这里提供一个样例,演示了怎么使用ajax进行单步验证, ...

  10. django 查询集 API

    filter 表示=, 返回一个新的QuerySet,包含与给定的查询参数匹配的对象.exclude 表示!=. 返回一个新的QuerySet,它包含不满足给定的查找参数的对象. annotate 使 ...