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. vi语法高亮,自动缩进(转)

    编辑.vimrc 这样文件在其中加入如下两行就可以了,此法对#号提示符下的操作无效. let &termencoding=&encodingset fileencodings=utf- ...

  2. Debian9.3安装NW360无线网卡驱动

    最近想把家里的一台老旧台式机利用起来,打算安装Debian9.3,下载ISO,用PowerISO写入到U盘,然后开始安装,过程基本顺利. 就是中间提示缺少“rtl_nic/rtl8105e-1.fw” ...

  3. Linux 修改终端显示bash-1.4$

    先取得root权限,然后在终端如下操作[root@host]$su -然后输入密码接着[root@host]#PS1='[\u@\H \W]\$' 你取得root权限后在,在终端命令下输入这个,一定要 ...

  4. 【PHP原生】获取字符串所有汉字首字母和首个汉字首字母

    1.废话不多说,看代码,获取字符串汉字首字母,兼容GBK和UTF-8 <?php //获取单个汉字拼音首字母.注意:此处不要纠结.汉字拼音是没有以U和V开头的 function getfirst ...

  5. JBoss类加载机制 ClassLoadingConfiguration

    http://sylven.iteye.com/blog/577063 类仓库优先级从低到高 1.classpath.lib目录 2.由已部署的应用程序的所有类./server/{server_nam ...

  6. 修改select下拉框的下拉按钮

    ie上的下拉框下拉按钮真是太丑了,如何把他自定义一下呢? 首先,把浏览器自带的下拉框去掉:  select::-ms-expand { display: none; } 接下来,用自己喜欢的下拉图片去 ...

  7. 两种方法一句代码隐藏Activity的标题栏

    把Activity的标题栏隐藏有两种方法.一种是在在Activity里面设置javacode.还有一种是在项目的清单文件AndroidManifest.xml中设置模版样式. 一.在Activity中 ...

  8. 高性能Web架构

    高性能Web架构 转自 架构文摘 2017-02-07 王杰  引言 最新中国互联网络信息中心(CNNIC)发布的<第38次中国互联网络发展状况统计报告>,2016年6月,我国网民规模达7 ...

  9. C#事件-自定义事件的使用方法(转载)

    1.声明一个委托类 public delegate SomethingChangedHandler(object sender,EventArgs e); 2.在你的类中声明一个事件绑定到该委托 pu ...

  10. 何为优秀的机器学习特征 zz

    提供好的特征是机器学习任务中最重要的工作,那么何为优秀的机器学习特征?以及如何高效地组合这些特征? 以二分类问题为例,好的特征具有很好的区分性.例如学习任务是区分两种不同类型的狗:灰猎犬(Greyho ...