Django完整增删改查系统实例代码

目录
  • 一、效果图如下
  • 二、使用步骤
    • 1.创建并配置一个django项目
      • 1.1新建一个项目ch3
      • 1.2创建应用employee
      • 1.3指定ch3项目的应用程序emyployee
      • 1.4与数据库相连
      • 1.5 定义与使用模型
      • 1.6生成迁移文件
  • 二、实现数据库增删改查
    • 2.1视图文件
    • 2.2前端页面
      • 2.2.1主页面(list_dep_old.xml)
      • 2.2.2增加数据页面(add_dep_old.html)
      • 2.2.3修改页面(edit_dep_old.html)
    • 2.3在主项目中添加路由
  • 总结

一、效果图如下

二、使用步骤

1.创建并配置一个django项目

1.1新建一个项目ch3

django-admin startproject ch3

1.2创建应用employee

python manage.py startapp employee

1.3指定ch3项目的应用程序emyployee

在setting.py中INSTALLED_APPS下加入employee应用程序

1.4与数据库相连

1.在数据库中创建一个数据库名为testOrm
2.在setting.py文件添加与数据库连接的信息
3.添加模文件夹

1.5 定义与使用模型

模型定义在应用employee的model.py文件中,并继承model.Model类。在本次项目中定义了模型类department

class department(models.Model):
    dep_name=models.CharField(max_length=32,verbose_name='部门名称',unique=True,blank=False)
    dep_script=models.CharField(max_length=60,verbose_name='备注说明',null=True

1.6生成迁移文件

python manage.py makemigrations

执行生产迁移命令后会生成一下0001_initial.py文件

迁移文件生成后,使用迁移文件命令生成对应的数据表

python manage.py migrate

二、实现数据库增删改查

2.1视图文件

实现增删改查的方法

# 查询所有数据
def list_dep_old(request):
    # 查询所有数据
    def_list=department.objects.all()#查询方法:all(),filter(),exclude(),get()
    return render(request,'test_orm_old/list_dep_old.html',{'dep_list':def_list})
#添加数据
def add_dep_old(request):
    # 判断请求方式,如果post,说明前端需要提交数据
    if request.method=='POST':
        # 获取传过来的get()函数中的参数(html文件input()标签的name属性)
        dep_name=request.POST.get('dep_name')
        dep_script=request.POST.get('dep_script')
    # strip()过滤
        if dep_name.strip()=='':
            return render(request,'test_orm_old/add_dep_old.html',{'error_info':'名称不能为空'})
        # 用create()函数新建一条函数,会自动保存,不需要调用save()函数
        try:
            # 添加数据有两种方式:1.使用模型管理器的create()方法添加数据,2.使用模型实列save()方法保存
            p=department.objects.create(dep_name=dep_name,dep_script=dep_script)
            return redirect('/test_orm_old/list_dep_old/')
        except Exception as e:
            return render(request,'test_orm_old/add_dep_old.html',{'error_info':'输入部门名称重复或信息错误!'})
        finally:
            pass
    return render(request,'test_orm_old/add_dep_old.html/')
#删除数据
def del_dep_old(request,dep_id):
    dep_object=department.objects.get(id=dep_id)
    dep_object.delete()
    return redirect('/test_orm_old/list_dep_old/')
#修改数据
def edit_dep_old(request,dep_id):
    if request.method=='POST':
        id=request.POST.get('id')
        dep_name=request.POST.get('dep_name')
        dep_script=request.POST.get('dep_script')
        dep_object=department.objects.get(id=id)
        dep_object.dep_name=dep_name
        dep_object.dep_script=dep_script
        dep_object.save()
        return redirect('/test_orm_old/list_dep_old/')
    else:
        dep_object=department.objects.get(id=dep_id)
        return render(request,'test_orm_old/edit_dep_old.html',{'department':dep_object})

2.2前端页面

1.在应用下创建templates文件目录用来存放前端页面文件
2.并在templates下创建test_orm_old文件目录

2.2.1主页面(list_dep_old.xml)

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>主页面</title>
</head>
<body>
<h1>部门列表</h1>
<div><a href="/test_orm_old/add_dep_old" rel="external nofollow" >增加一条记录</a></div>
<table border="1">
    <thead>
    <tr>
        <td>部门名称</td>
        <td>备注说明</td>
        <td colspan="2">操作</td>
    </tr>
    </thead>
    <tbody>
    {% for dep in dep_list %}
    <tr>
        <td>{{ dep.dep_name }}</td>
        <td>{{ dep.dep_script}}</td>
        <td><a href="/test_orm_old/del_dep_old/{{dep.id}}/" rel="external nofollow" >删除</a> </td>
        <td><a href="/test_orm_old/edit_dep_old/{{dep.id}}/" rel="external nofollow" >修改</a> </td>
    </tr>
    {% empty %}
        <tr>
            <td colspan="4">无相关记录!</td>
        </tr>
    {% endfor %}
    </tbody>
</table>
</body>
</html>

2.2.2增加数据页面(add_dep_old.html)

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>增加部门</title>
</head>
<body>
<div align="center">
    <h1>增加部门</h1>
    <hr>
    <form action="" method="post">
<!--        安全机制-->
        {% csrf_token %}
        <input type="hidden" name="id" id="id" value="{{ department.id }}">
        <div>
            <label>部门名称:</label>
                <input type="text" name="dep_name" id="dep_name">
        </div>
        <br>
        <div>
            <label>备注说明:</label>
                <input type="text" name="dep_script" id="dep_script">
        </div>
        <br>
        <div>
            <input type="submit" value="保存">
        </div>
    </form>
    {{ error_info }}
</div>
</body>
</html>

2.2.3修改页面(edit_dep_old.html)

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>修改部门</title>
</head>
<body>
<div align="center">
    <h1>修改部门</h1>
    <form action="" method="post">
        {% csrf_token %}
        <input type="hidden" name="id" id="id" value="{{ department.id}}">
        <div>
            <label>部门:</label>
                <input type="text" name="dep_name" id="dep_name" value="{{ department.dep_name }}">
        </div>
        <br>
        <div>
            <label>备注:</label>
                <input type="text" name="dep_script" id="dep_script" value="{{ department.dep_script}}">
        </div>
        <br>
        <div><input type="submit" value="保存"></div>
    </form>
    {{ error_info }}
</div>
</body>
</html>

2.3在主项目中添加路由

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

from employee import views

urlpatterns = [
    path('admin/', admin.site.urls),
    # path('',include('employee.urls')),
    path('test/',views.test),
    path('list_dep_old/',views.list_dep_old),
    path('test_orm_old/list_dep_old/',views.list_dep_old),
    path('test_orm_old/add_dep_old/',views.add_dep_old),
    path('test_orm_old/del_dep_old/<int:dep_id>/',views.del_dep_old),
]

总结

注意一定要配置好每一步。

到此这篇关于Django完整增删改查系统的文章就介绍到这了,更多相关Django增删改查系统内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • python Django连接MySQL数据库做增删改查

    1.下载安装MySQLdb类库http://www.djangoproject.com/r/python-mysql/2.修改settings.py 配置数据属性 复制代码 代码如下: DATABASES = {    'default': {        'ENGINE': 'django.db.backends.mysql', # Add 'postgresql_psycopg2', 'mysql', 'sqlite3' or 'oracle'.        'NAME': 'djang

  • Django数据库操作的实例(增删改查)

    创建数据库中的一个表 class Business(models.Model): #自动创建ID列 caption = models.CharField(max_length=32) code = models.CharField(max_length=32) 1.增加 方法一 models.Business.objects.create(caption='市场部',code='123') 方法二 obj = models.UserInfo(caption='市场部',code='123') o

  • 使用Django开发简单接口实现文章增删改查

    1.一些准备工作  安装django pip install django 创建django项目 进入项目代码存放目录执行命令: django-admin.py startproject blog_demo 进入blog_demo,运行命令: python3.6 manage.py runserver 9000 在浏览器地址栏打开:http://127.0.0.1:9000/ 如果出现以下画面,则说明服务器正在运行 创建博客应用(app) django中每一个app可以看作是一个模块,以app为

  • python Django实现增删改查实战代码

    1.先创建个app子级 python .\manage.py startapp app01 然后创建数据模型 app01下的modules.py文件 from django.db import models # Create your models here. class UserInfo(models.Model): name=models.CharField(max_length=32) password=models.CharField(max_length=12) age=models.

  • python django 增删改查操作 数据库Mysql

    下面介绍一下django增删改查操作: 1.view.py # -*- coding: utf-8 -*- from __future__ import unicode_literals from django.http import HttpResponse from polls.models import Test from django.shortcuts import render # Create your views here. # 解决乱码 import sys reload(sy

  • Django完整增删改查系统实例代码

    目录 一.效果图如下 二.使用步骤 1.创建并配置一个django项目 1.1新建一个项目ch3 1.2创建应用employee 1.3指定ch3项目的应用程序emyployee 1.4与数据库相连 1.5 定义与使用模型 1.6生成迁移文件 二.实现数据库增删改查 2.1视图文件 2.2前端页面 2.2.1主页面(list_dep_old.xml) 2.2.2增加数据页面(add_dep_old.html) 2.2.3修改页面(edit_dep_old.html) 2.3在主项目中添加路由 总

  • java使用DOM对XML文档进行增删改查操作实例代码

    本文研究的主要是java使用DOM对XML文档进行增删改查操作的相关代码,具体实例如下所示. 源代码: package com.zc.homeWork18; import java.io.File; import javax.xml.parsers.DocumentBuilder; import javax.xml.parsers.DocumentBuilderFactory; import javax.xml.transform.Transformer; import javax.xml.tr

  • 从vue基础开始创建一个简单的增删改查的实例代码(推荐)

    1.安装vue-cli    cnpm install vue-cli -g  --执行全局安装 2.创建一个webpack的基础项目:命令:vue init webpack myproject; 以下是项目的目录结构及说明 build是webpack配置 build.js       // 生产环境构建代码 check-versions.js // 检查node&npm等版本 utils.js          // 构建配置公用工具 vue-loader.conf.js // vue加载器

  • node实现简单的增删改查接口实例代码

    node实现简单的增删改查接口的全部代码如下: // 数据存储在users.json文件中 const express = require("express"); const fs = require("fs"); const cors = require("cors"); const bodyParser = require("body-parser"); const app = express(); app.use(cor

  • Mybatis注解增删改查的实例代码

    要点 有另一种方法来完成语句映射. 它们映射的语句可以不用 XML 来配置,而可以使用 Java 注解来配置. 使用注解来映射简单语句会使代码显得更加简洁,但对于稍微复杂一点的语句,Java 注解不仅力不从心,还会让你本就复杂的 SQL 语句更加混乱不堪. 如果你需要做一些很复杂的操作,最好用 XML 来映射语句. 需要在config.xml中注册Java接口 <mappers> <mapper class="com.mybatis.DAO.PeopleMapper"

  • java实现单链表增删改查的实例代码详解

    package 数据结构算法.链表; /* *定义节点 * 链表由节点构成 */ public class Node<E> { private E e; //数据data private Node<E> next; //指向下一个节点 public Node() { } public Node(E e) { this.e = e; } public Node<E> getNext() { return next; } public void setNext(Node&l

  • hibernate通过session实现增删改查操作实例解析

    今天学习了一下如何通过hibernate来实现对数据库的增删改查,下面来简单介绍一下: 首先创建个Student类: package com.hibernate.model; import javax.persistence.Column; import javax.persistence.Entity; import javax.persistence.GeneratedValue; import javax.persistence.Id; import javax.persistence.T

  • iOS 对plist文件进行读写,增删改查的实例

    对plist文件进行读写 //获取路径对象 NSArray *pathArray = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES); NSString *path = [pathArray objectAtIndex:0]; //获取文件的完整路径 NSString *filePatch = [path stringByAppendingPathComponent:@"column.

  • Node连接MySQL并封装其增删改查的实现代码

    目录 Node连接Mysql 安装Mysql模块 连接Mysql 常用的SQL语句 Node操作Mysql 封装 结束 Node连接Mysql 说到node,可能大家会想到MOngoDB作为数据库,这里将会介绍node与mysql的连接,并分享了封装好的实例代码,在项目开发中可直接使用. 安装Mysql模块 npm install mysql 连接Mysql const mysql = require('mysql'); let connection = mysql.createConnecti

  • ASP.NET实现Hadoop增删改查的示例代码

    本文介绍了ASP.NET实现Hadoop增删改查的示例代码,分享给大家,具体如下: packages.config <?xml version="1.0" encoding="utf-8"?> <packages> <package id="Microsoft.AspNet.WebApi.Client" version="4.0.20505.0" targetFramework="net

随机推荐