Python+Django+MySQL实现基于Web版的增删改查的示例代码


Posted in Python onMay 13, 2020

 前言

本篇使用Python Web框架Django连接和操作MySQL数据库学生信息管理系统(SMS),主要包含对学生信息增删改查功能,旨在快速入门Python Web,少走弯路。效果演示在项目实战最后一节,文章结尾有整个项目的源码地址。

开发环境

  •  开发工具:Pycharm 2020.1
  • 开发语言:Python 3.8.0
  • Web框架:Django 3.0.6
  • 数据库:MySQL5.7
  • 操作系统:Windows 10

项目实战

1. 创建项目

File->New Project->Django

Python+Django+MySQL实现基于Web版的增删改查的示例代码

稍等片刻,项目的目录结构如下图

Python+Django+MySQL实现基于Web版的增删改查的示例代码

项目创建后确认是否已安装Django和mysqlclient解释器,如何确认?file->Settings

Python+Django+MySQL实现基于Web版的增删改查的示例代码

如果没有请在Terminal终端输入以下命令完成安装

pip install django
pip install mysqlclient

Python+Django+MySQL实现基于Web版的增删改查的示例代码

如果在执行pip install 报错Read time out请设置延长下超时时间,默认15s,网络不好情况下很易超时

pip --default-timeout=180 install -U django
pip --default-timeout=180 install -U mysqlclient

参数-U是--upgrade简写,把安装的包升级到最新版本

2. 创建应用

打开Pycharm的Terminal终端,输入以下命令创建sims应用

python manage.py startapp sims

应用创建后要在项目的settings.py文件里的INSTALLED_APPS下面添加smis完成应用注册

Python+Django+MySQL实现基于Web版的增删改查的示例代码

3.配置MySQL数据库

在本地MySQL创建sms数据库,修改项目的settings连接信息由默认的sqlite修改为MySQL

Python+Django+MySQL实现基于Web版的增删改查的示例代码

DATABASES = {
 'default': {
 'ENGINE': 'django.db.backends.mysql',
 'NAME': 'sms',
 'USER': 'root',
 'PASSWORD': '123456',
 'HOST': '127.0.0.1',
 'PORT': 3306
 }
}

测试连接,依次点击Pycharm右上角的Database->+->Data Source->MySQL

Python+Django+MySQL实现基于Web版的增删改查的示例代码

下载连接驱动和配置数据库连接信息

Python+Django+MySQL实现基于Web版的增删改查的示例代码

点击Test Connection测试连接,连接通过点击OK出现如下的结构信息表示连接本地MySQL成功

Python+Django+MySQL实现基于Web版的增删改查的示例代码

4.数据模型创建(M)

在应用sims下models.py添加Student模型

Python+Django+MySQL实现基于Web版的增删改查的示例代码

class Student(models.Model):
 student_no = models.CharField(max_length=32, unique=True)
 student_name = models.CharField(max_length=32)

5.数据模型迁移

Terminal终端输入以下两条命令,其作用第一条生成文件记录模型的变化;第二条是将模型变化同步至数据库,我们可以在数据库生成对应的表结构。

python manage.py makemigrations sims
python manage.py migrate sims

生成数据表结构如下所示

Python+Django+MySQL实现基于Web版的增删改查的示例代码

6.路由配置

本质可以理解请求路径url和处理方法的映射配置,首先在项目sms的urls.py文件中添加sims的路由配置

from django.contrib import admin
from django.urls import path
from django.conf.urls import url, include

urlpatterns = [
 path('admin/', admin.site.urls),
 url(r'^sims/', include('sims.urls'))
]

然后在sims添加一个名为urls.py的文件,添加路由配置如下

Python+Django+MySQL实现基于Web版的增删改查的示例代码

# coding=utf-8
from django.conf.urls import url
from . import views

urlpatterns = [
 url(r'^$', views.index),
 url(r'^add/$', views.add),
 url(r'^edit/$', views.edit),
 url(r'^delete/$', views.delete)
]

7.处理函数添加(V)

在应用sims的视图层文件views.py添加对应学生信息增删改查的处理函数,这里我使用的原生SQL,便于深入理解其执行过程。后面有时间我会在github上添加Django框架提供的操作数据库方式。

import MySQLdb
from django.shortcuts import render, redirect


# Create your views here.
# 学生信息列表处理函数
def index(request):
 conn = MySQLdb.connect(host="localhost", user="root", passwd="123456", db="sms", charset='utf8')
 with conn.cursor(cursorclass=MySQLdb.cursors.DictCursor) as cursor:
 cursor.execute("SELECT id,student_no,student_name FROM sims_student")
 students = cursor.fetchall()
 return render(request, 'student/index.html', {'students': students})

# 学生信息新增处理函数
def add(request):
 if request.method == 'GET':
 return render(request, 'student/add.html')
 else:
 student_no = request.POST.get('student_no', '')
 student_name = request.POST.get('student_name', '')
 conn = MySQLdb.connect(host="localhost", user="root", passwd="123456", db="sms", charset='utf8')
 with conn.cursor(cursorclass=MySQLdb.cursors.DictCursor) as cursor:
  cursor.execute("INSERT INTO sims_student (student_no,student_name) "
    "values (%s,%s)", [student_no, student_name])
  conn.commit()
 return redirect('../')

# 学生信息修改处理函数
def edit(request):
 if request.method == 'GET':
 id = request.GET.get("id")
 conn = MySQLdb.connect(host="localhost", user="root", passwd="123456", db="sms", charset='utf8')
 with conn.cursor(cursorclass=MySQLdb.cursors.DictCursor) as cursor:
  cursor.execute("SELECT id,student_no,student_name FROM sims_student where id =%s", [id])
  student = cursor.fetchone()
 return render(request, 'student/edit.html', {'student': student})
 else:
 id = request.POST.get("id")
 student_no = request.POST.get('student_no', '')
 student_name = request.POST.get('student_name', '')
 conn = MySQLdb.connect(host="localhost", user="root", passwd="123456", db="sms", charset='utf8')
 with conn.cursor(cursorclass=MySQLdb.cursors.DictCursor) as cursor:
  cursor.execute("UPDATE sims_student set student_no=%s,student_name=%s where id =%s",
    [student_no, student_name, id])
  conn.commit()
 return redirect('../')

# 学生信息删除处理函数
def delete(request):
 id = request.GET.get("id")
 conn = MySQLdb.connect(host="localhost", user="root", passwd="123456", db="sms", charset='utf8')
 with conn.cursor(cursorclass=MySQLdb.cursors.DictCursor) as cursor:
 cursor.execute("DELETE FROM sims_student WHERE id =%s", [id])
 conn.commit()
 return redirect('../')

8.模板页面创建(T)

Python+Django+MySQL实现基于Web版的增删改查的示例代码

学生信息列表页

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <title>学生列表</title>
</head>
<body>
<table border="1px" width="100%" style="border-collapse: collapse;">
 <a href="../sims/add">添加学生</a>
 <tr>
  <th>编号</th>
  <th>姓名</th>
  <th>学号</th>
  <th>操作</th>
 </tr>
 {% for student in students %}
  <tr>
   <td align="center">{{ forloop.counter }} </td>
   <td align="center">{{ student.student_name }} </td>
   <td align="center">{{ student.student_no }} </td>
   <td align="center">
    <a href="../sims/edit/?id={{ student.id }}">
     编辑
    </a>
    <a href="../sims/delete/?id={{ student.id }}">
     删除
    </a>
   </td>
  </tr>
 {% endfor %}
</table>
</body>
</html>

学生信息新增页

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <title>学生添加</title>
 <style>
  form {
   margin: 20px auto;
   width: 500px;
   border: 1px solid #ccc;
   padding: 20px
  }
 </style>
</head>
<body>
<form method="post" action="../add/">
 {% csrf_token %}
 <table>
  <tr>
   <th>姓名</th>
   <td><input name="student_name"></td>
  </tr>
  <tr>
   <th>学号</th>
   <td><input name="student_no"/></td>
  </tr>
  <tr>
   <td colspan="2">
    <input type="submit"/>
   </td>
  </tr>
 </table>
</form>
</body>
</html>

学生信息编辑页

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <title>学生编辑</title>
 <style>
  form {
   margin: 20px auto;
   width: 500px;
   border: 1px solid #ccc;
   padding: 20px
  }
 </style>
</head>
<body>
<form method="post" action="../edit/">
 {% csrf_token %}
 <input type="hidden" name="id" value="{{ student.id }}"/>
 <table>
  <tr>
   <th>姓名</th>
   <td><input name="student_name" value="{{ student.student_name }}"></td>
  </tr>
  <tr>
   <th>学号</th>
   <td><input name="student_no" value="{{ student.student_no }}"/></td>
  </tr>
  <tr>
   <td colspan="2">
    <input type="submit"/>
   </td>
  </tr>
 </table>
</form>
</body>
</html>

9.启动web服务测试

Terminal终端输入以下命令启动web服务

python manage.py runserver

Python+Django+MySQL实现基于Web版的增删改查的示例代码

服务启动后,打开浏览器输入http://127.0.0.1:8000/sims/即可进入学生信息管理列表页

10.功能演示

最后最重要的事情,看效果。我这里简单演示下,话不多说,看动态图

Python+Django+MySQL实现基于Web版的增删改查的示例代码

结语

至此,基于Python+Django+MySQL环境搭建一个拥有增删改查功能的Python Web就完成了。希望能够真正帮到大家快速入门Python Web开发。如果在搭建过程中您有遇到什么问题,欢迎在下方留言,看到我会立即回复的!可以的话给个关注哦,谢谢您!

附录

最后附上项目整个源码的github仓库地址 https://github.com/hxrui/python-diango-web.git,欢迎star交流学习。

到此这篇关于Python+Django+MySQL实现基于Web版的增删改查的文章就介绍到这了,更多相关Python+Django+MySQL实现基于Web版的增删改查内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Python 相关文章推荐
Python random模块常用方法
Nov 03 Python
Python中的localtime()方法使用详解
May 22 Python
python 表达式和语句及for、while循环练习实例
Jul 07 Python
Python3 中文文件读写方法
Jan 23 Python
python实现集中式的病毒扫描功能详解
Jul 09 Python
python变量的存储原理详解
Jul 10 Python
TensorFlow实现简单的CNN的方法
Jul 18 Python
python cumsum函数的具体使用
Jul 29 Python
python中使用while循环的实例
Aug 05 Python
Python Print实现在输出中插入变量的例子
Dec 25 Python
Python实现读取并写入Excel文件过程解析
May 27 Python
Python脚本破解压缩文件口令实例教程(zipfile)
Jun 14 Python
Python使用Numpy模块读取文件并绘制图片
May 13 #Python
python pyecharts 实现一个文件绘制多张图
May 13 #Python
Django与pyecharts结合的实例代码
May 13 #Python
django Layui界面点击弹出对话框并请求逻辑生成分页的动态表格实例
May 12 #Python
Python爬取阿拉丁统计信息过程图解
May 12 #Python
PyPDF2读取PDF文件内容保存到本地TXT实例
May 12 #Python
Python3.7下安装pyqt5的方法步骤(图文)
May 12 #Python
You might like
PHPLog php 程序调试追踪工具
2009/09/09 PHP
一个漂亮的php验证码类(分享)
2013/08/06 PHP
通过代码实例解析PHP session工作原理
2020/12/11 PHP
js技巧--转义符&quot;\&quot;的妙用
2007/01/09 Javascript
ExtJs扩展之GroupPropertyGrid代码
2010/03/05 Javascript
animate动画示例(泪奔的小孩)及stop和delay的使用
2013/05/06 Javascript
JavaScript简介
2015/02/15 Javascript
AngularJS模块详解及示例代码
2016/08/17 Javascript
javascript鼠标跟随运动3种效果(眼球效果,苹果菜单,方向跟随)
2016/10/27 Javascript
jQuery实现的点击标题文字切换字体效果示例【测试可用】
2018/04/26 jQuery
如何对react hooks进行单元测试的方法
2019/08/14 Javascript
关于JS解构的5种有趣用法
2019/09/05 Javascript
js中forEach,for in,for of循环的用法示例小结
2020/03/14 Javascript
解决vue打包 npm run build-test突然不动了的问题
2020/11/13 Javascript
[02:51]DOTA2英雄基础教程 艾欧
2014/01/13 DOTA
python检测是文件还是目录的方法
2015/07/03 Python
python3 shelve模块的详解
2017/07/08 Python
Python各类图像库的图片读写方式总结(推荐)
2018/02/23 Python
Python生成短uuid的方法实例详解
2018/05/29 Python
pytorch简介
2020/11/11 Python
CSS3 制作绽放的莲花采用效果叠加实现
2013/01/31 HTML / CSS
Kiehl’s科颜氏西班牙官方网站:源自美国的植物护肤品牌
2020/02/22 全球购物
德国便宜的宠物店:Brekz.de
2020/10/23 全球购物
中职生自我鉴定范文
2013/10/03 职场文书
应届生高等护理求职信
2013/10/12 职场文书
党员自我评价分享
2013/12/13 职场文书
小学毕业感言150字
2014/02/05 职场文书
《蓝色的树叶》教学反思
2014/02/24 职场文书
篝火晚会主持词
2014/03/25 职场文书
物业管理专业自荐信
2014/07/01 职场文书
幼儿园社区活动总结
2014/07/07 职场文书
建筑工程造价专业自荐信
2014/07/08 职场文书
劳动纠纷调解协议书格式
2014/11/30 职场文书
2015年街道除四害工作总结
2015/05/15 职场文书
2015年青年教师工作总结
2015/05/25 职场文书
网聊搭讪开场白
2015/05/28 职场文书