Django完整增删改查系统


提示:以下是本篇文章正文内容,下面案例可供参考

一、效果图如下

在这里插入图片描述

二、使用步骤

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(
  • 10
    点赞
  • 63
    收藏
    觉得还不错? 一键收藏
  • 15
    评论
好的,这是一个很好的问题!使用Django编写图书管理系统,可以分为以下几个步骤: 1. 创建Django项目和应用程序。 在终端中使用以下命令创建一个新的Django项目: ``` django-admin startproject book_management_system ``` 接下来,使用以下命令创建一个名为“books”的新应用程序: ``` python manage.py startapp books ``` 2. 设计数据模型。 在“books”应用程序的models.py文件中定义一个Book类作为数据模型,例如: ``` from django.db import models class Book(models.Model): title = models.CharField(max_length=200) author = models.CharField(max_length=100) published_date = models.DateField() isbn = models.CharField(max_length=20) def __str__(self): return self.title ``` 3. 创建数据库表。 在终端中运行以下命令来创建数据库表: ``` python manage.py makemigrations books python manage.py migrate ``` 4. 创建视图。 在“books”应用程序的views.py文件中创建以下视图函数: ``` from django.shortcuts import render, redirect from .models import Book def book_list(request): books = Book.objects.all() return render(request, 'books/book_list.html', {'books': books}) def book_detail(request, pk): book = Book.objects.get(pk=pk) return render(request, 'books/book_detail.html', {'book': book}) def book_create(request): if request.method == 'POST': title = request.POST['title'] author = request.POST['author'] published_date = request.POST['published_date'] isbn = request.POST['isbn'] book = Book(title=title, author=author, published_date=published_date, isbn=isbn) book.save() return redirect('book_detail', pk=book.pk) else: return render(request, 'books/book_form.html') def book_update(request, pk): book = Book.objects.get(pk=pk) if request.method == 'POST': book.title = request.POST['title'] book.author = request.POST['author'] book.published_date = request.POST['published_date'] book.isbn = request.POST['isbn'] book.save() return redirect('book_detail', pk=book.pk) else: return render(request, 'books/book_form.html', {'book': book}) def book_delete(request, pk): book = Book.objects.get(pk=pk) book.delete() return redirect('book_list') ``` 这些视图函数分别处理图书列表、图书详情、创建图书、更新图书和删除图书等操作。 5. 创建模板。 在“books”应用程序的templates目录下创建以下模板: book_list.html: ``` {% extends 'base.html' %} {% block content %} <h2>Books</h2> <ul> {% for book in books %} <li><a href="{% url 'book_detail' book.pk %}">{{ book.title }}</a></li> {% empty %} <li>No books yet.</li> {% endfor %} </ul> <a href="{% url 'book_create' %}">Add a book</a> {% endblock %} ``` book_detail.html: ``` {% extends 'base.html' %} {% block content %} <h2>{{ book.title }}</h2> <p>Author: {{ book.author }}</p> <p>Published date: {{ book.published_date }}</p> <p>ISBN: {{ book.isbn }}</p> <a href="{% url 'book_update' book.pk %}">Edit</a> <a href="{% url 'book_delete' book.pk %}">Delete</a> {% endblock %} ``` book_form.html: ``` {% extends 'base.html' %} {% block content %} <h2>{{ form_title }}</h2> <form method="POST"> {% csrf_token %} <label for="title">Title:</label> <input type="text" name="title" value="{{ book.title if book else '' }}" required><br> <label for="author">Author:</label> <input type="text" name="author" value="{{ book.author if book else '' }}" required><br> <label for="published_date">Published date:</label> <input type="date" name="published_date" value="{{ book.published_date if book else '' }}" required><br> <label for="isbn">ISBN:</label> <input type="text" name="isbn" value="{{ book.isbn if book else '' }}" required><br> <input type="submit" value="Save"> </form> {% endblock %} ``` base.html: ``` <!DOCTYPE html> <html> <head> <title>Book Management System</title> </head> <body> <nav> <a href="{% url 'book_list' %}">Books</a> </nav> {% block content %} {% endblock %} </body> </html> ``` 6. 创建URL模式。 在“books”应用程序的urls.py文件中创建以下URL模式: ``` from django.urls import path from . import views urlpatterns = [ path('', views.book_list, name='book_list'), path('<int:pk>/', views.book_detail, name='book_detail'), path('create/', views.book_create, name='book_create'), path('<int:pk>/update/', views.book_update, name='book_update'), path('<int:pk>/delete/', views.book_delete, name='book_delete'), ] ``` 7. 运行项目并测试。 在终端中运行以下命令来启动Django开发服务器: ``` python manage.py runserver ``` 然后在浏览器中访问http://localhost:8000/books/,就可以看到图书列表页面了。您可以进行添加、编辑和删除等操作,并查看每本图书的详细信息。 希望这个回答能够帮到您!
评论 15
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值