一、项目依赖包安装

1、安装Django(2.2.7)

pip3 install django

2、安装DjangoRestFramework

因为DjangoRestFramework是基于Django开发的,因此安装之前必须安装Django

pip3 install djangorestframework

 3、安装markdown和django-filter

pip3 install markdown django-filter

 4、Pycharm创建项目

  更换虚拟环境,这样便于开发所安装特定的包,然而包环境都有特定的,便于管理。

 

 5、测试项目是否正常

  一定要将MxShop下的urls.py中的文件中的admin注释掉,因为我们没有注册admin所以一定会报错,说是没有定义admin,因此需要注释在运行。

测试成功,说明项目没出现问题,接下来开始整个项目最重要的一环啦,项目中的设置。

6、settings.py中的数据库设置(第一个是默认的,第二个是配置的)

# Database
# https://docs.djangoproject.com/en/2.2/ref/settings/#databases DATABASES = {
'default': {
'ENGINE': 'django.db.backends.sqlite3',
'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
}
}
# Database
# https://docs.djangoproject.com/en/2.2/ref/settings/#databases DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',#声明连接什么数据库
'NAME': "mxshop",#数据库的名字
'USER': 'root',#数据库用户名
'PASSWORD': '',#数据库的密码,
'HOST': '127.0.0.1',#数据库地址
'PORT':'',#数据库端口
}
}

然后来到虚拟环境配置相关包

7、安装pymysql进行相关配置

pip3 install pymysql

 

8、数据库创建

然后运行,发现有如下错误:

说的是mysqlclient版本不一致,直接往报错的一行点进去,找到报错的点,然后进去注释相关语句:(不要害怕源码,源码都是我们的工具,改动工具只是为了更好地造坦克)

改动完,运行试试,就可以发现完成啦,当然还有其他办法比如直接安装驱动mysqlclient(支持所有版本),设置里面数据库配置,就可以愉快比这个更快完成

windows安装这些包都容易出错,因此可以找到前面一篇那个包错误网址,进去直接搜索找到对应版本的包手动下载安装。

9、安装图片处理包pillow

pip3 install -i https://pypi.douban.com/simple pillow

 10、项目中建立需要的文件包或者文件夹

  apps是将所有的应用拖到这下面,方便管理,extra_apps是将一些不想安装到虚拟环境的包,下载源码放到这里面,这样便于我们修改源码,打造我们想要的情况。media文件夹是保存上传的一些文件。

11、项目设置里面设置识别路径

添加这两行代码:#将appsextra_apps加入到路径中来,以便撰写代码方便

import sys

sys.path.insert(0,BASE_DIR)
sys.path.insert(0,os.path.join(BASE_DIR,"apps"))
sys.path.insert(0,os.path.join(BASE_DIR,"extra_apps"))

二、app应用模型设计

 1、创建应用

  根据前端显示的页面,分析出需要设计的app应用,然后创建应用

2、在项目settings.py注册应用

# Application definition

INSTALLED_APPS = [
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'users.apps.UsersConfig',
'users', #将我们创建的app注册到这里面来
'goods',
'trade',
'user_operation',
]

三、模型类设计

1、应用users模型类设计(编写代码需要遵循PEP8规范)

  我们需要重新设计用户的模型类,Django自带的模型类不能满足我们的要求,因此重新继承django.contrib.auth.models.AbstractUser这个类,新增加我们需要的新字段。

users.models.py:

from django.contrib.auth.models import AbstractUser

# Create your models here.

class UserProfile(AbstractUser):
"""
用户信息相关
"""
name = models.CharField(max_length=30,null=True,blank=True,verbose_name="姓名")
birthday = models.DateField(null=True,blank=True,verbose_name="出生年月")
gender = models.CharField(max_length=6,choices=(("male","男"),("female","女")),default="female",verbose_name="性别")
mobile = models.CharField(max_length=11,verbose_name="电话")
email = models.EmailField(max_length=100,null=True,blank=True,verbose_name="邮箱") class Meta:
verbose_name = "用户"
verbose_name_plural = verbose_name def __str__(self):
return self.name

  经过分析,会发现与用户相关的验证码,也需要保存到用户这里,当然可以保存到redis里更佳,为了积累项目的流程,增加自己对项目的理解,需要将验证码保存到数据库,以便于对整个项目开发有更深的理解。

users.models.py

from datetime import datetime

class VerifyCode(models.Model):
"""
短信验证码
"""
code = models.CharField(max_length=10,verbose_name="验证码")
mobile = models.CharField(max_length=11, verbose_name="电话")
#不用括号是模型类调用的时间,然而加括号是模型类迁移的时间
add_time = models.DateTimeField(default=datetime.now,verbose_name="添加时间") class Meta:
verbose_name = "短信验证码"
verbose_name_plural = verbose_name def __str__(self):
return self.code

UserProfile设计完成之后,没有替换系统的用户,因此我们需要到项目settings.py中去添加下面这一行:

AUTH_USER_MODEL = "users.UserProfile"

 2、应用goods的模型类设计(PEP8规范)

通过一个模型类完成商品的级别分类,

goods.models.py:

from datetime import datetime

from django.db import models
from DjangoUeditor.models import UEditorField # Create your models here. class GoodsCategory(models.Model):
"""
商品类别(比如生鲜食品<----海鲜水产<---鱼)
这样就可以将所有商品放到一个表中
"""
CATEGORY_TYPE = (
(1,"一级类目"),
(2,"二级类目"),
(3,"三级类目")
)
#help_text以后文档有用,related_name以后查询有用
name = models.CharField(default="",max_length=30,verbose_name="类别名",help_text="类别名")
#查找商品可能用英文查找,加此字段为了以后查找方便
code = models.CharField(default="",max_length=30,verbose_name="类别code",help_text="类别code")
desc = models.TextField(default="",verbose_name="类别描述",help_text="类别描述")
category_type = models.CharField(choices=CATEGORY_TYPE,verbose_name="类目级别",help_text="类目级别")
parent_category = models.ForeignKey("self",null=True,blank=True,verbose_name="父类目级别",related_name="sub_cat",help_text="父目录")
is_tab = models.BooleanField(default=False,verbose_name="是否导航",help_text="是否导航")
add_time = models.DateTimeField(default=datetime.now, verbose_name="添加时间") class Meta:
verbose_name = "商品类别"
verbose_name_plural = verbose_name def __str__(self):
return self.name class GoodsCategoryBrand(models.Model):
"""
品牌名
"""
name = models.CharField(default="",max_length=30,verbose_name="品牌名",help_text="品牌名")
desc = models.TextField(default="",max_length=200,verbose_name="品牌描述",help_text="品牌描述")
image = models.ImageField(max_length=200,upload_to="brand/images/")
add_time = models.DateTimeField(default=datetime.now,verbose_name="添加时间") class Meta:
verbose_name = "品牌"
verbose_name_plural = verbose_name def __str__(self):
return self.name class Goods(models.Model):
"""
商品
"""
category = models.ForeignKey(GoodsCategory, verbose_name="商品类目")
goods_sn = models.CharField(max_length=50, default="", verbose_name="商品唯一货号")
name = models.CharField(max_length=100, verbose_name="商品名")
click_num = models.IntegerField(default=0, verbose_name="点击数")
sold_num = models.IntegerField(default=0, verbose_name="商品销售量")
fav_num = models.IntegerField(default=0, verbose_name="收藏数")
goods_num = models.IntegerField(default=0, verbose_name="库存数")
market_price = models.FloatField(default=0, verbose_name="市场价格")
shop_price = models.FloatField(default=0, verbose_name="本店价格")
goods_brief = models.TextField(max_length=500, verbose_name="商品简短描述")
goods_desc = UEditorField(verbose_name=u"内容", imagePath="goods/images/", width=1000, height=300,
filePath="goods/files/", default='')
ship_free = models.BooleanField(default=True, verbose_name="是否承担运费")
goods_front_image = models.ImageField(upload_to="goods/images/", null=True, blank=True, verbose_name="封面图")
is_new = models.BooleanField(default=False, verbose_name="是否新品")
is_hot = models.BooleanField(default=False, verbose_name="是否热销")
add_time = models.DateTimeField(default=datetime.now, verbose_name="添加时间") class Meta:
verbose_name = '商品'
verbose_name_plural = verbose_name def __str__(self):
return self.name class Banner(models.Model):
"""
轮播的商品
"""
goods = models.ForeignKey(Goods, verbose_name="商品")
image = models.ImageField(upload_to='banner', verbose_name="轮播图片")
index = models.IntegerField(default=0, verbose_name="轮播顺序")
add_time = models.DateTimeField(default=datetime.now, verbose_name="添加时间") class Meta:
verbose_name = '轮播商品'
verbose_name_plural = verbose_name def __str__(self):
return self.goods.name class GoodsImage(models.Model):
"""
商品轮播图
"""
goods = models.ForeignKey(Goods, verbose_name="商品", related_name="images")
image = models.ImageField(upload_to="", verbose_name="图片", null=True, blank=True)
add_time = models.DateTimeField(default=datetime.now, verbose_name="添加时间") class Meta:
verbose_name = '商品图片'
verbose_name_plural = verbose_name def __str__(self):
return self.goods.name

goods.models.py

代码里面的DjangoUeditor是富文本编辑器,是基于Django编写的,因此去github上找到py3支持的版本,下载源码,复制到extra_apps

然后去到项目设置settings.py中注册extra_apps中的DjangoUeditor

 3、应用trade的模型类设计(PEP8规范)

from datetime import datetime

from django.db import models
from django.contrib.auth import get_user_model from goods.models import Goods
#这里调用UserProfile直接调用django的配置方法,返回值就是UserProfile模型,
#这样的好处就是,不用知道用户模型类也可以调用
User = get_user_model()
# Create your models here. class ShoppingCart(models.Model):
"""
购物车
"""
user = models.ForeignKey(User, verbose_name=u"用户")
goods = models.ForeignKey(Goods, verbose_name=u"商品")
nums = models.IntegerField(default=0, verbose_name="购买数量") add_time = models.DateTimeField(default=datetime.now, verbose_name=u"添加时间") class Meta:
verbose_name = '购物车'
verbose_name_plural = verbose_name
unique_together = ("user", "goods") def __str__(self):
return "%s(%d)".format(self.goods.name, self.nums) class OrderInfo(models.Model):
"""
订单
"""
ORDER_STATUS = (
("TRADE_SUCCESS", "成功"),
("TRADE_CLOSED", "超时关闭"),
("WAIT_BUYER_PAY", "交易创建"),
("TRADE_FINISHED", "交易结束"),
("paying", "待支付"),
) user = models.ForeignKey(User, verbose_name="用户")
order_sn = models.CharField(max_length=30, null=True, blank=True, unique=True, verbose_name="订单号")
trade_no = models.CharField(max_length=100, unique=True, null=True, blank=True, verbose_name=u"交易号")
pay_status = models.CharField(choices=ORDER_STATUS, default="paying", max_length=30, verbose_name="订单状态")
post_script = models.CharField(max_length=200, verbose_name="订单留言")
order_mount = models.FloatField(default=0.0, verbose_name="订单金额")
pay_time = models.DateTimeField(null=True, blank=True, verbose_name="支付时间") # 用户信息
address = models.CharField(max_length=100, default="", verbose_name="收货地址")
signer_name = models.CharField(max_length=20, default="", verbose_name="签收人")
singer_mobile = models.CharField(max_length=11, verbose_name="联系电话") add_time = models.DateTimeField(default=datetime.now, verbose_name="添加时间") class Meta:
verbose_name = u"订单"
verbose_name_plural = verbose_name def __str__(self):
return str(self.order_sn) class OrderGoods(models.Model):
"""
订单的商品详情
"""
order = models.ForeignKey(OrderInfo, verbose_name="订单信息", related_name="goods")
goods = models.ForeignKey(Goods, verbose_name="商品")
goods_num = models.IntegerField(default=0, verbose_name="商品数量") add_time = models.DateTimeField(default=datetime.now, verbose_name="添加时间") class Meta:
verbose_name = "订单商品"
verbose_name_plural = verbose_name def __str__(self):
return str(self.order.order_sn)

trade.models.py

4、用户操作models.py设计

from datetime import datetime

from django.db import models
from django.contrib.auth import get_user_model from goods.models import Goods
# Create your models here.
User = get_user_model() class UserFav(models.Model):
"""
用户收藏
"""
user = models.ForeignKey(User, verbose_name="用户")
goods = models.ForeignKey(Goods, verbose_name="商品", help_text="商品id")
add_time = models.DateTimeField(default=datetime.now, verbose_name=u"添加时间") class Meta:
verbose_name = '用户收藏'
verbose_name_plural = verbose_name
unique_together = ("user", "goods") def __str__(self):
return self.user.username class UserLeavingMessage(models.Model):
"""
用户留言
"""
MESSAGE_CHOICES = (
(1, "留言"),
(2, "投诉"),
(3, "询问"),
(4, "售后"),
(5, "求购")
)
user = models.ForeignKey(User, verbose_name="用户")
message_type = models.IntegerField(default=1, choices=MESSAGE_CHOICES, verbose_name="留言类型",
help_text=u"留言类型: 1(留言),2(投诉),3(询问),4(售后),5(求购)")
subject = models.CharField(max_length=100, default="", verbose_name="主题")
message = models.TextField(default="", verbose_name="留言内容", help_text="留言内容")
file = models.FileField(upload_to="message/images/", verbose_name="上传的文件", help_text="上传的文件")
add_time = models.DateTimeField(default=datetime.now, verbose_name="添加时间") class Meta:
verbose_name = "用户留言"
verbose_name_plural = verbose_name def __str__(self):
return self.subject class UserAddress(models.Model):
"""
用户收货地址
"""
user = models.ForeignKey(User, verbose_name="用户" )
province = models.CharField(max_length=100, default="", verbose_name="省份")
city = models.CharField(max_length=100, default="", verbose_name="城市")
district = models.CharField(max_length=100, default="", verbose_name="区域")
address = models.CharField(max_length=100, default="", verbose_name="详细地址")
signer_name = models.CharField(max_length=100, default="", verbose_name="签收人")
signer_mobile = models.CharField(max_length=11, default="", verbose_name="电话")
add_time = models.DateTimeField(default=datetime.now, verbose_name="添加时间") class Meta:
verbose_name = "收货地址"
verbose_name_plural = verbose_name def __str__(self):
return self.address

user_operation.models.py

四、数据表迁移

1、数据表迁移makemigrations与migrate

  将Django模型类中的数据库迁移生成数据表,是大大简化我们对数据库的操作,节约大量时间,这样开发效率大大提升,当使用makemigrations的时候,全部应用app下面会出现一个文件001-初始化文件,同时,在数据库中的django-migration表中会有相应app的记录,因此如果迁移表数据库会出现对应app的两条记录,因此了解原理,以后迁移数据的时候,可以删除初始化文件001,或者删除数据库,第二次必须使用migrate才会讲对应的模型类转化为数据表,

下面这个错误是在Django2.0以后,在外键关系和一对一关系的时候,必须加上参数on_delete的值。

五、Xadmin后台管理系统的配置

  因为做项目就是为了磨炼不同的技术,重复性的工作就不用再做,前面项目都做过前后端不分离项目,慕学在线网项目,因此利用Xadmin打造后台管理系统直接可以将配置好的复制进来,如果想要直接这个项目就做的话,那么可以自己去github上学习Xadmin的相关配置以及操作。

  将配置好的Xadmin插件复制到extra_apps,然后将每个应用下面的adminx.py文件复制到特定的应用下面,adminx的作用也是将模型类注册到后台管理系统中操作。

完成以上操作那么继续下面的操作

1、项目设置中配置xadmin

# Application definition   注册xadmin

INSTALLED_APPS = [
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'users.apps.UsersConfig',
'goods',
'trade',
'user_operation',
'DjangoUeditor',
'xadmin',
'crispy_forms',#这个是xadmin需要使用的
]

2、安装xadmin的依赖包

  去github上搜索xadmin,然后找到依赖包。

  在虚拟环境中,安装所有的依赖包。

pip3 install django-crispy-forms django-import-export django-reversion django-formtools future httplib2 six

在安装两个包,是帮助我们做excel文件的:

pip3 install xlwt xlsxwriter

安装完成后,需要迁移Xadmin的数据表

然后会发现,由于Xadmin跟不上Django的版本节奏,因此将Xadmin中的源码改动,下面这个博客错误记录很全:

https://www.cnblogs.com/xingfuggz/p/10142388.html

完成之后,运行去数据库库查看一下,添加完成。接下来需要给xadmin注册访问路径。

 3、注册Xadmin路由(Mxshop/ulrs.py)

from django.urls import path
import xadmin
urlpatterns = [
path('xadmin/', xadmin.site.urls),
]

注册完xadmin之后,我们应该创建我们的超级管理员,去检验我们的xadmin是否生效。

4、创建超级管理员

python manage.py createsuperuser

创建之后来到项目设置里面(settings.py)将时区换为亚洲上海的。

设置好后启动,可以运行,记住xadmin必须和Django匹配,否则会出现版本不相容的问题,github上有很多人对Xadmin进行修改,适合用于Django2.0以后的版本,

然后再将这个注册到设置里面启动访问,然后发现成功

进去全部都点一下,试试会不会出错,然后发现报错

直接点进去,根据报错信息,说render函数得到一个错误的参数,将93行注释掉,这样就可以启动啦

02-model设计的更多相关文章

  1. Go语言之高级篇beego框架之model设计构造查询

    一.model设计构造查询 QueryBuilder 提供了一个简便,流畅的 SQL 查询构造器.在不影响代码可读性的前提下用来快速的建立 SQL 语句. QueryBuilder 在功能上与 ORM ...

  2. 3- vue django restful framework 打造生鲜超市 - model设计和资源导入

    3- vue django restful framework 打造生鲜超市 - model设计和资源导入 使用Python3.6与Django2.0.2(Django-rest-framework) ...

  3. (生鲜项目)02. app与model设计

    第一步: 设计app 1. 根据业务需求,设计合适的app板块,这里,我们将拥有goods,trade,user_operation, users四个app 2. 然后去注册app 第二步: 设计us ...

  4. Kubernetes系列02—Kubernetes设计架构和设计理念

    本文收录在容器技术学习系列文章总目录 1.Kubernetes设计架构 Kubernetes集群包含有节点代理kubelet和Master组件(APIs, scheduler, etc),一切都基于分 ...

  5. django model设计与实际数据库表的对比

    # 文章class Article(models.Model): title = models.CharField('标题', max_length=70) excerpt = models.Text ...

  6. 设计模式应用场景之Model设计中可以用到的设计模式

    在开发中,不同的场景适用不同的设计模式.对于开发建模方面,可以根据模型的抽象类型设计成简单属性模式和复杂组合模式. 因为组合模式中的属性为多种类型对象,可操作性也比较灵活. 而针对这种复杂数据结构,有 ...

  7. Model设计中常见的技巧和注意事项

    verbose_name 可以作为第一个参数传入,书写更加工整和有序: name = models.CharField('类别名',default="", max_length=3 ...

  8. 02: CMDB设计思路

    1.1 cmdb理解   参考博客:https://www.cnblogs.com/laowenBlog/p/6825420.html   参考博客2:https://www.cnblogs.com/ ...

  9. Topic Model的分类和设计原则

    Topic Model的分类和设计原则 http://blog.csdn.net/xianlingmao/article/details/7065318 topic model的介绍性文章已经很多,在 ...

  10. 2020,最新Model的设计-APP重构之路

    很多的app使用MVC设计模式来将“用户交互”与“数据和逻辑”分开,而model其中一个重要作用就是持久化.下文中设计的Model可能不是一个完美的,扩展性强的model范例,但在我需要重构的app中 ...

随机推荐

  1. python编程基础之十一

    循环语句:周而复始,在满足某个条件下,重复做相同或类型的事情, 循环语句三要素:循环条件 + 循环体 + 循环条件改变while 条件 : 循环体 循环条件改变... while 条件 : 循环体 循 ...

  2. UVA - 1160 X-Plosives

    A secret service developed a new kind of explosive that attain its volatile property only when a spe ...

  3. HDU 1428漫步校园

    漫步校园 Problem Description LL最近沉迷于AC不能自拔,每天寝室.机房两点一线.由于长时间坐在电脑边,缺乏运动.他决定充分利用每次从寝室到机房的时间,在校园里散散步.整个HDU校 ...

  4. css中em单位详解,说明

    em详解      em可以理解成“倍”. em会以父级元素中所设置的字体像素值为基准值进行成倍放大: 字体大小=(父级元素中的字体像素 * em的值) 例: 网页部分代码如下: 1.我现在没有在父级 ...

  5. django 后端开发-01 配置工作:

    # Django 配置工作 1: 配置好数据库 2: 配置好模板文件路径 3: 配置好静态文件路径 4: 配置好时区 5: 配置好模板的static标签 1:  配置好数据库 1.1 配置django ...

  6. 【RabbitMQ 实战指南】一 死信队列

    1.死信队列 DLX,全称为 Dead-Letter-Exchange,可以称之为死信交换器.当消息在一个队列中变成死信(dead message)之后,它能被发送到另一个交换器中,这个交换器就是DL ...

  7. SpringBoot-Mysql模板多数据源加载

    SpringBoot-Mysql模板多数据源加载 qq交流群: 812321371 微信交流群: MercyYao 简介 在 java 项目里常用到 mysql 多数据源操作.结合 springboo ...

  8. Juc1024小半年总结-面试篇

    大家好,我叫Juc 这大概是我时隔2年度多 第一次以分享的形式发的第一篇公众号 今天是2019年10月26 本想在10月24就分享一下 可惜前面两天时间太忙... 很凑巧,今天我出来工作刚好满4个月, ...

  9. 打python&adb组合拳,实现微信读书永久免费读

    用过“微信读书”的朋友都知道,如果我们想阅读全本的付费书籍,除了购买整本(使用书币)外,还可以使用无限卡.可无论是购买全书还是无限卡,归根结底都是要花银子的. 除此之外,还有一种方式——用阅读时长兑换 ...

  10. 如何利用Fiddler4进行Android APP / IOS APP抓包

    Fiddler抓包 1.Fiddler介绍 Fiddler是一个http协议调试代理工具,它能够记录并检查所有你的电脑和互联网之间的http通讯,设置断点,查看所有的“进出”Fiddler的数据. F ...