基于 Django 的手机管理系统实现过程详解


Posted in Python onAugust 16, 2019

一、概述

打算通过设计数据库,然后结合 Python 框架Django,实现在网页上对数据库的增删改查(本例以手机的管理为例,不考虑订购功能),有普通用户界面和管理员用户界面,普通用户只能做简单的查看需求,管理员用户可以实现对数据库内容的实时修改。

网站主体如下图:

基于 Django 的手机管理系统实现过程详解

二、设计数据库

根据业务需求,设计数据表,需要下列这些属性:

手机型号、品牌、手机描述、出厂年份、价格、照片、产地。

根据数据表设计原则,数据表设计需要满足基本的函数依赖和范式要求,因此我们将上述属性拆分为四张表格,并建立这些数据表之间的联系,相关的E-R 图如图所示:

(由于 Django 在建立每一个数据表的时候就会有一个内建的 id 作为主键,因此在此就不需要另外再设置主键字段)

基于 Django 的手机管理系统实现过程详解

此数据库字段由于是我从 sqlite 迁移到 MySQL 中,Django 自动帮我再生成的字段,所以有些字段名和我在 Django 写的字段不一致,但数据表关系还是一致的。

在 Django 中设计数据表相关代码如下:

from django.db import models

# Create your models here.

class Maker(models.Model):
 name = models.CharField(max_length=10)
 country = models.CharField(max_length=10)

 def __str__(self):
  return self.name

class PModel(models.Model):
 maker = models.ForeignKey(Maker, on_delete=models.CASCADE)
 name = models.CharField(max_length=20)
 url = models.URLField(default='http://i.imgur.com/OusiGB.png')

 def __str__(self):
  return self.name

class Product(models.Model):
 pmodel = models.ForeignKey(PModel, on_delete=models.CASCADE, verbose_name='型号')
 nickname = models.CharField(max_length=15, default='超值二手手机', verbose_name='摘要')
 description = models.TextField(default='暂无说明', verbose_name='暂无说明')
 year = models.PositiveIntegerField(default=2016, verbose_name='出厂年份')
 price = models.PositiveIntegerField(default=0, verbose_name='价格')

 def __str__(self):
  return self.nickname

class PPhoto(models.Model):
 product = models.ForeignKey(Product, on_delete=models.CASCADE)
 description = models.CharField(max_length=20, default='产品照片')
 url = models.URLField(default='http://i.imgur.com/z230eeq.png')

 def __str__(self):
  return self.description

在终端下执行以下指令,进行数据库的更新以及迁移操作,并创建管理员用户:

python manage.py makemigrations
python manage.py migrate
python manage.py createsuperuser
python manage.py runserver

然后插入数据。

注意安装 Python 的 MySQL 驱动程序这块,刚开始安装 MySQL 官网提供的 mysql-python 这个模块,但在 Python3环境下会报错,原因是mysql-python 模块不支持 Python3版本,所以安装使用pymysql 模块。
注意在 models.py 文件同级文件中的init.py 修改为:

import pymysql
pymysql.install_as_MySQLdb()

操作便与 mysql-python 的使用方法一致了。

网站管理员登录界面:

基于 Django 的手机管理系统实现过程详解

管理员的增删改查界面:

基于 Django 的手机管理系统实现过程详解

三、设计网站

设计网站,在 Django 中增加 static 文件和 template 文件,套用相关模板和框架(这里运用了 bootstrap),编写 HTML 文件,调用数据库中的内容,设计的网站如下(即普通用户能查看的界面):

主页面:

基于 Django 的手机管理系统实现过程详解

商品详情界面:

基于 Django 的手机管理系统实现过程详解

四、总结

至此,一个简单的 手机管理系统就被我们实现出来了(Django + Bootstrap + MySQL),当然其中还存在中很多的不足,比如没有实现普通用户登录功能,HTML 页面写的也比较简陋,后续有时间会继续加以完善。
代码已上传至 GitHub:

https://github.com/weixuqin/myDjango/tree/master/test3

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
从零学python系列之从文件读取和保存数据
May 23 Python
Python实现批量把SVG格式转成png、pdf格式的代码分享
Aug 21 Python
Go语言基于Socket编写服务器端与客户端通信的实例
Feb 19 Python
Python实现简单的获取图片爬虫功能示例
Jul 12 Python
Python中标准库OS的常用方法总结大全
Jul 19 Python
python批量替换多文件字符串问题详解
Apr 22 Python
Python中的异常处理try/except/finally/raise用法分析
Feb 28 Python
Django框架模板的使用方法示例
May 25 Python
Python日志syslog使用原理详解
Feb 18 Python
python实现学生成绩测评系统
Jun 22 Python
Python基于traceback模块获取异常信息
Jul 23 Python
Python高并发解决方案实现过程详解
Jul 31 Python
python创建与遍历List二维列表的方法
Aug 16 #Python
python每天定时运行某程序代码
Aug 16 #Python
pyinstaller打包opencv和numpy程序运行错误解决
Aug 16 #Python
Python Web框架之Django框架Form组件用法详解
Aug 16 #Python
Python自动化导出zabbix数据并发邮件脚本
Aug 16 #Python
python禁用键鼠与提权代码实例
Aug 16 #Python
Python函数装饰器原理与用法详解
Aug 16 #Python
You might like
把77A收信机改造成收音机
2021/03/02 无线电
Zend Framework教程之Application和Bootstrap用法详解
2016/03/10 PHP
PHP自动生成缩略图函数的源码示例
2019/03/18 PHP
laravel 实现登陆后返回登陆前的页面方法
2019/10/03 PHP
Extjs EditorGridPanel中ComboBox列的显示问题
2011/07/04 Javascript
Textbox控件注册回车事件及触发按钮提交事件具体实现
2013/03/04 Javascript
javascript简单事件处理和with用法介绍
2013/09/16 Javascript
jQuery多项选项卡的实现思路附样式及代码
2014/06/03 Javascript
JS实现部分HTML固定页面顶部随屏滚动效果
2015/12/24 Javascript
js阻止默认浏览器行为与冒泡行为的实现代码
2016/05/15 Javascript
AngularJS使用ng-options指令实现下拉框
2016/08/23 Javascript
JS与jQuery实现子窗口获取父窗口元素值的方法
2017/04/17 jQuery
javascript中json对象json数组json字符串互转及取值方法
2017/04/19 Javascript
微信小程序实现倒计时60s获取验证码
2020/04/17 Javascript
详解vue.js移动端配置flexible.js及注意事项
2019/04/10 Javascript
Nodejs环境实现socket通信过程解析
2020/07/03 NodeJs
Python 2.7.x 和 3.x 版本的重要区别小结
2014/11/28 Python
独特的python循环语句
2016/11/20 Python
Python基于生成器迭代实现的八皇后问题示例
2018/05/23 Python
tensorflow实现图像的裁剪和填充方法
2018/07/27 Python
解决Python发送Http请求时,中文乱码的问题
2020/04/30 Python
Python+Kepler.gl轻松制作酷炫路径动画的实现示例
2020/06/02 Python
使用OpenCV获取图片连通域数量,并用不同颜色标记函
2020/06/04 Python
Python文件操作模拟用户登陆代码实例
2020/06/09 Python
使用CSS3的rem属性制作响应式页面布局的要点解析
2016/05/24 HTML / CSS
HTML5打开本地app应用的方法
2016/03/31 HTML / CSS
工作室成员个人发展规划范文
2014/01/24 职场文书
《匆匆》教学反思
2014/02/22 职场文书
岗位聘任书范文
2014/03/29 职场文书
保证书格式范文
2014/04/28 职场文书
公司新人试用期自我评价
2014/09/17 职场文书
个人借款协议书范本
2014/11/17 职场文书
建议书范文
2015/02/05 职场文书
jQuery实现影院选座订座效果
2021/04/13 jQuery
详解nginx location指令
2022/01/18 Servers
python turtle绘制多边形和跳跃和改变速度特效
2022/03/16 Python