基于django图书信息管理系统的搭建(增删改查)

✍django项目搭建教程 ☞ -----------------教程

本文主要讲解django如何连接数据库MySQL并且可视化展示,实现增删改查功能


目录

[一. 创建django应用](#一. 创建django应用)

[二. 数据库配置](#二. 数据库配置)

[三. 查看数据库](#三. 查看数据库)

[四. 编写代码](#四. 编写代码)

4.1视图函数

[4.2 配置URL](#4.2 配置URL)

4.3创建模板文件

[4.3.1 book_list.html](#4.3.1 book_list.html)

[4.3.2 book_create.html](#4.3.2 book_create.html)

[4.3.3 book_update.html](#4.3.3 book_update.html)

[五. 系统展示](#五. 系统展示)

[六. 更多干货](#六. 更多干货)


一. 创建django应用

在创建完项目的基础上创建应用,点击文章首部"教程" 0基础也能搭建好项目

python 复制代码
python manage.py startapp myapp ---应用名为myapp,可自行修改

创建完应用在项目文件夹下的settings.py中的INSTALLED_APPS 添加一行 "myapp"

项目文件夹下会出现 myapp 文件夹,定义模型 在 myapp/models.py 文件中定义 Book 模型

python 复制代码
from django.db import models

class Book(models.Model): ------表结构
    title = models.CharField(max_length=200)
    author = models.CharField(max_length=100)
    publication_year = models.IntegerField()

    def __str__(self):
        return self.title

二. 数据库配置

在项目文件夹下的settings.py添加

python 复制代码
DATABASES = {
    # "default": {
    #     "ENGINE": "django.db.backends.sqlite3",
    #     "NAME": BASE_DIR / "db.sqlite3",
    # }
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': 'date',----数据库名字
        'USER': 'root',
        'PASSWORD': '123456',
        'HOST': '127.0.0.1',
        'PORT': '3306'
    }

}

注意:配置完成后,在MySQL执行CREATE DATABASE date 命令创建数据库

迁移数据库:执行以下命令来创建数据库表

python 复制代码
python manage.py makemigrations
python manage.py migrate

和下图一致表明成功了

三. 查看数据库

我们可以看到自动生成了如下表,其中最下面的表就是我们所定义的book模型

四. 编写代码

4.1视图函数

在 myapp/views.py 文件中编写视图函数

python 复制代码
from django.shortcuts import render, redirect
from.models import Book

def book_list(request):
    books = Book.objects.all()
    return render(request, 'book_list.html', {'books': books})

def book_create(request):
    if request.method == 'POST':
        title = request.POST['title']
        author = request.POST['author']
        publication_year = request.POST['publication_year']
        Book.objects.create(title=title, author=author, publication_year=publication_year)
        return redirect('book_list')
    return render(request, 'book_create.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.publication_year = request.POST['publication_year']
        book.save()
        return redirect('book_list')
    return render(request, 'book_update.html', {'book': book})

def book_delete(request, pk):
    book = Book.objects.get(pk=pk)
    book.delete()
    return redirect('book_list')

4.2 配置URL

项目文件夹下的urls.py 文件中配置URL

python 复制代码
from django.contrib import admin
from django.urls import path
from myapp.views import book_list, book_create, book_update, book_delete

urlpatterns = [
    path('admin/', admin.site.urls),
    path('books/', book_list, name='book_list'),
    path('books/create/', book_create, name='book_create'),
    path('', book_update, name='book_update'),
    path('', book_delete, name='book_delete'),
]

4.3创建模板文件

在 myapp/templates 目录下创建以下HTML文件,没有目录则先创建目录

4.3.1 book_list.html

html 复制代码
<!DOCTYPE html>
<html>
<head>
    <title>Book List</title>
</head>
<body>
    <h1>Book List</h1>
    Create New Book
    <ul>
        {% for book in books %}
        <li>{{ book.title }} - {{ book.author }} ({{ book.publication_year }})
            Update
            Delete
        </li>
        {% endfor %}
    </ul>
</body>
</html>

4.3.2 book_create.html

html 复制代码
<!DOCTYPE html>
<html>
<head>
    <title>Create Book</title>
</head>
<body>
    <h1>Create New Book</h1>
    <form method="post">
        {% csrf_token %}
        <label for="title">Title:</label><br>
        <input type="text" id="title" name="title" required><br>
        <label for="author">Author:</label><br>
        <input type="text" id="author" name="author" required><br>
        <label for="publication_year">Publication Year:</label><br>
        <input type="number" id="publication_year" name="publication_year" required><br>
        <input type="submit" value="Create">
    </form>
</body>
</html>

4.3.3 book_update.html

html 复制代码
<!DOCTYPE html>
<html>
<head>
    <title>Update Book</title>
</head>
<body>
    <h1>Update Book</h1>
    <form method="post">
        {% csrf_token %}
        <label for="title">Title:</label><br>
        <input type="text" id="title" name="title" value="{{ book.title }}" required><br>
        <label for="author">Author:</label><br>
        <input type="text" id="author" name="author" value="{{ book.author }}" required><br>
        <label for="publication_year">Publication Year:</label><br>
        <input type="number" id="publication_year" name="publication_year" value="{{ book.publication_year }}" required><br>
        <input type="submit" value="Update">
    </form>
</body>
</html>

五. 系统展示

六. 更多干货

------------ -- ✈✈✈

1.如果我的博客对你有帮助或你喜欢我的博客内容,请 "👍点赞" "✍️评论" "★收藏" 一键三连哦!

2.❤️【👇🏻👇🏻👇🏻关注我| 获取更多源码 | 优质文章】 带您学习各种前端插件、3D炫酷效果、图片展示、文字效果、以及整站模板 、HTML模板 、微信小程序模板 、等! 「在这里一起探讨知识,互相学习」!

3.以上内容技术相关问题✉欢迎一起交流学习 ☟ ☟ ☟

相关推荐
喵手5 分钟前
Python爬虫实战:针对Python官网,精准提取出每一个历史版本的版本号、发布日期以及对应的文档/详情页链接等信息,并最终清洗为标准化的CSV文件!
爬虫·python·爬虫实战·零基础python爬虫教学·python官方数据采集·采集历史版本版本号等信息·导出csv文件
Elieal12 分钟前
SpringBoot 数据层开发与企业信息管理系统实战
java·spring boot·后端
Coder_Boy_13 分钟前
Java开发者破局指南:跳出内卷,借AI赋能,搭建系统化知识体系
java·开发语言·人工智能·spring boot·后端·spring
独自破碎E18 分钟前
BISHI23 小红书推荐系统
java·后端·struts
databook19 分钟前
像搭积木一样思考:数据科学中的“自下而上”之道
python·数据挖掘·数据分析
luoluoal19 分钟前
基于python的医疗问句中的实体识别算法的研究(源码+文档)
python·mysql·django·毕业设计·源码
gustt23 分钟前
构建全栈AI应用:集成Ollama开源大模型
前端·后端·ollama
千寻girling28 分钟前
《 MongoDB 教程 》—— 不可多得的 MongoDB
前端·后端·面试
Wiittch28 分钟前
HashMap源码深度剖析
后端
啊阿狸不会拉杆29 分钟前
《机器学习导论》第 9 章-决策树
人工智能·python·算法·决策树·机器学习·数据挖掘·剪枝