图书管理系统BMS
图书管理系统BMS
效果图:
主要代码:
表关系的创建:
from django.db import models
# Create your models here.
class Book(models.Model):
"""图书表"""
title = models.CharField(max_length=32, verbose_name='书名')
price = models.DecimalField(max_digits=8, decimal_places=2, verbose_name='价格')
publish_time = models.DateField(auto_now_add=True)
# kucun = models.IntegerField(verbose_name='库存数', default=1000) # 设置默认值
# maichu = models.IntegerField(verbose_name='卖出数', null=True) # 允许为空
# 书籍与出版社的一对多关系字段
publish = models.ForeignKey(to='Publish', on_delete=models.CASCADE)
# 书籍与作者的多对多关系字段(自动创建第三张表)
authors = models.ManyToManyField(to='Author')
def __str__(self):
return f'书籍对象:{self.title}'
class Publish(models.Model):
"""出版社表"""
name = models.CharField(max_length=32, verbose_name='名称')
address = models.CharField(max_length=64, verbose_name='地址')
def __str__(self):
return f'出版社对象:{self.name}'
class Author(models.Model):
"""作者表"""
name = models.CharField(max_length=32, verbose_name='姓名')
age = models.IntegerField(verbose_name='年龄')
# 作者与作者详情的一对一关系
author_detail = models.OneToOneField(to='AuthorDetail', on_delete=models.CASCADE)
def __str__(self):
return f'作者对象:{self.name}'
class AuthorDetail(models.Model):
"""作者详情表"""
phone = models.BigIntegerField(verbose_name='电话号码')
address = models.CharField(max_length=32, verbose_name='家庭地址')
urls:
from django.contrib import admin
from django.urls import path
from app01 import views
urlpatterns = [
path('admin/', admin.site.urls),
# 首页的编写
path('home/', views.home_func,name='home_view'),
# 图书列表展示页
path('/book_list',views.book_list_func,name='book_list_view'),
# 图书数据添加页
path('/book_add', views.book_add_func, name='book_add_view'),
# 图书数据编辑页
path('/book_edit/<int:book_pk>/', views.book_edit_func,name='book_edit_view'),
# 图书数据删除接口
path('book_delete/<int:book_pk>/', views.book_delete_func, name='book_delete_view')
]
views:
from django.shortcuts import render,redirect,HttpResponse
from app01 import models
# Create your views here.
def home_func(request):
return render(request,'homePage.html')
def book_list_func(request):
# 1.获取所有的数据 # queryset [数据对象,数据对象]
book_queryset = models.Book.objects.all()
# 2.返回html页面并在页面上展示图书数据
return render(request,'bookListPage.html',locals())
def book_add_func(request):
if request.method == 'POST':
title = request.POST.get('title')
price = request.POST.get('price')
publish_time = request.POST.get('publish_time')
publish_id = request.POST.get('publish_id')
author_id_list = request.POST.get('author_id_list')
book_obj = models.Book.objects.create(title=title, price=price, publish_time=publish_time,
publish_id=publish_id
)
book_obj.authors.add(*author_id_list) # add(1,2,3)
# 重定向到书籍展示页
return redirect('book_list_view') # 只支持没有动态匹配的别名反向解析
# 2.分析可得页面需要出版社和作者的全部数据
publish_queryset = models.Publish.objects.all()
author_queryset = models.Author.objects.all()
# 1.返回一个可以让用户输入书籍相关数据的html页面
return render(request,'bookAddPage.html',locals())
def book_edit_func(request, book_pk):
# 1.根据匹配到的数据主键值查询数据对象
edit_obj = models.Book.objects.filter(pk=book_pk).first()
if request.method == 'POST':
title = request.POST.get('title') # 列表最后一个数据值
price = request.POST.get('price') # 列表最后一个数据值
publish_time = request.POST.get('publish_time') # 列表最后一个数据值
publish_id = request.POST.get('publish_id') # 列表最后一个数据值
author_id_list = request.POST.getlist('author_id_list') # 获取完整的列表数据
models.Book.objects.filter(pk=book_pk).update(title=title, price=price, publish_time=publish_time,
publish_id=publish_id)
edit_obj.authors.set(author_id_list)
return redirect('book_list_view')
# 3.分析可得编辑页也需要所有的出版社和作者信息
publish_queryset = models.Publish.objects.all()
author_queryset = models.Author.objects.all()
# 2.传递给html页面并展示给用户看
return render(request, 'bookEditPage.html', locals())
def book_delete_func(request, book_pk):
# 删除书籍与作者的绑定关系
delete_book_obj = models.Book.objects.filter(pk=book_pk).first()
delete_book_obj.authors.clear()
# 删除书籍数据
models.Book.objects.filter(pk=book_pk).delete()
return redirect('book_list_view')
homePage.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.6.0/jquery.js"></script>
{% load static %}
<link rel="stylesheet" href="{% static 'bootstrap-3.4.1-dist/css/bootstrap.min.css' %}">
<script src="{% static 'bootstrap-3.4.1-dist/js/bootstrap.min.js' %}"></script>
{% block css %}
{% endblock %}
</head>
<body>
<nav class="navbar navbar-inverse">
<div class="container-fluid">
<!-- Brand and toggle get grouped for better mobile display -->
<div class="navbar-header">
<button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#bs-example-navbar-collapse-1" aria-expanded="false">
<span class="sr-only">Toggle navigation</span>
<span class="icon-bar"></span>
<span class="icon-bar"></span>
<span class="icon-bar"></span>
</button>
<a class="navbar-brand" href="#">BMS</a>
</div>
<!-- Collect the nav links, forms, and other content for toggling -->
<div class="collapse navbar-collapse" id="bs-example-navbar-collapse-1">
<ul class="nav navbar-nav">
<li class="active"><a href="#">图书 <span class="sr-only">(current)</span></a></li>
<li><a href="#">作者</a></li>
<li class="dropdown">
<a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-haspopup="true" aria-expanded="false">Dropdown <span class="caret"></span></a>
<ul class="dropdown-menu">
<li><a href="#">Action</a></li>
<li><a href="#">Another action</a></li>
<li><a href="#">Something else here</a></li>
<li role="separator" class="divider"></li>
<li><a href="#">Separated link</a></li>
<li role="separator" class="divider"></li>
<li><a href="#">One more separated link</a></li>
</ul>
</li>
</ul>
<form class="navbar-form navbar-left">
<div class="form-group">
<input type="text" class="form-control" placeholder="Search">
</div>
<button type="submit" class="btn btn-default">查询</button>
</form>
<ul class="nav navbar-nav navbar-right">
<li><a href="#">Jia</a></li>
<li class="dropdown">
<a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-haspopup="true" aria-expanded="false">更多操作 <span class="caret"></span></a>
<ul class="dropdown-menu">
<li><a href="#">Action</a></li>
<li><a href="#">Another action</a></li>
<li><a href="#">Something else here</a></li>
<li role="separator" class="divider"></li>
<li><a href="#">Separated link</a></li>
</ul>
</li>
</ul>
</div><!-- /.navbar-collapse -->
</div><!-- /.container-fluid -->
</nav>
<div class="container-fluid">
<div class="row">
<div class="col-md-2">
<div class="list-group">
<a href="{% url 'home_view' %}" class="list-group-item active">首页展示</a>
<a href="{% url 'book_list_view' %}" class="list-group-item list-group-item-success">图书列表</a>
<a href="#" class="list-group-item list-group-item-info">出版社列表</a>
<a href="#" class="list-group-item list-group-item-warning">作者列表</a>
<a href="#" class="list-group-item list-group-item-danger">更多详情</a>
</div>
<div class="list-group">
<a href="{% url 'home_view' %}" class="list-group-item active">首页展示</a>
<a href="#" class="list-group-item list-group-item-success">图书列表</a>
<a href="#" class="list-group-item list-group-item-info">出版社列表</a>
<a href="#" class="list-group-item list-group-item-warning">作者列表</a>
<a href="#" class="list-group-item list-group-item-danger">更多详情</a>
</div>
<div class="list-group">
<a href="{% url 'home_view' %}" class="list-group-item active">首页展示</a>
<a href="#" class="list-group-item list-group-item-success">图书列表</a>
<a href="#" class="list-group-item list-group-item-info">出版社列表</a>
<a href="#" class="list-group-item list-group-item-warning">作者列表</a>
<a href="#" class="list-group-item list-group-item-danger">更多详情</a>
</div>
</div>
<div class="col-md-10">
<div class="panel panel-primary">
<div class="panel-heading">
<h3 class="panel-title">BMS</h3>
</div>
{% block content %}
<div class="panel-body">
<div class="page-header">
<h1>图书管理系统<small>Subtext for header</small></h1>
</div>
</div>
</div>
<div class="row">
<div class="col-xs-6 col-md-3">
<a href="#" class="thumbnail">
<img src="https://img0.baidu.com/it/u=2261625525,2052751300&fm=253&fmt=auto&app=138&f=JPEG?w=490&h=500" alt="...">
</a>
</div>
<div class="col-xs-6 col-md-3">
<a href="#" class="thumbnail">
<img src="https://img1.baidu.com/it/u=3510388477,472874873&fm=253&fmt=auto&app=120&f=JPEG?w=350&h=350" alt="...">
</a>
</div>
<div class="col-xs-6 col-md-3">
<a href="#" class="thumbnail">
<img src="http://t13.baidu.com/it/u=3150272070,2516947182&fm=224&app=112&f=JPEG?w=500&h=500" alt="...">
</a>
</div>
<div class="col-xs-6 col-md-3">
<a href="#" class="thumbnail">
<img src="https://img0.baidu.com/it/u=3978485405,2459936864&fm=253&fmt=auto&app=120&f=JPEG?w=500&h=500" alt="...">
</a>
</div>
</div>
<div class="row">
<div class="col-xs-6 col-md-3">
<a href="#" class="thumbnail">
<img src="https://img0.baidu.com/it/u=2261625525,2052751300&fm=253&fmt=auto&app=138&f=JPEG?w=490&h=500" alt="...">
</a>
</div>
<div class="col-xs-6 col-md-3">
<a href="#" class="thumbnail">
<img src="https://img1.baidu.com/it/u=3510388477,472874873&fm=253&fmt=auto&app=120&f=JPEG?w=350&h=350" alt="...">
</a>
</div>
<div class="col-xs-6 col-md-3">
<a href="#" class="thumbnail">
<img src="http://t13.baidu.com/it/u=3150272070,2516947182&fm=224&app=112&f=JPEG?w=500&h=500" alt="...">
</a>
</div>
<div class="col-xs-6 col-md-3">
<a href="#" class="thumbnail">
<img src="https://img0.baidu.com/it/u=3978485405,2459936864&fm=253&fmt=auto&app=120&f=JPEG?w=500&h=500" alt="...">
</a>
</div>
</div>
{% endblock %}
</div>
</div>
</div>
</div>
{% block js %}
{% endblock %}
</body>
</html>
bookListPage.html
{% extends 'homePage.html'%}
{% block content %}
<h2>图书展示页</h2>
<a href="{% url 'book_add_view' %}" class="btn btn-success">图书添加</a>
<table class="table table-striped table-hover">
<thead>
<tr>
<th>编号</th>
<th>书名</th>
<th>价格</th>
<th>日期</th>
<th>出版社</th>
<th>作者</th>
<th>操作</th>
</tr>
</thead>
<tbody>
{% for book_obj in book_queryset %}
<tr>
<td>{{ forloop.counter }}</td> <!--展示主键值也可以展示从1开始的有序数列-->
<td>{{ book_obj.title }}</td>
<td>{{ book_obj.price }}</td>
<td>{{ book_obj.publish_time|date:'Y-m-d' }}</td>
<td>{{ book_obj.publish.name }}</td>
<td>
{% for author_obj in book_obj.authors.all %}
{% if forloop.last %}
{{ author_obj.name }}
{% else %}
{{ author_obj.name }},
{% endif %}
{% endfor %}
</td>
<td>
<a href="{% url 'book_edit_view' book_obj.pk %}" class="btn btn-primary btn-xs">编辑</a>
<a href="{% url 'book_delete_view' book_obj.pk %}" class="btn btn-danger btn-xs delBtn">删除</a>
</td>
</tr>
{% endfor %}
</tbody>
</table>
<nav aria-label="Page navigation" class="text-center">
<ul class="pagination">
<li>
<a href="#" aria-label="Previous">
<span aria-hidden="true"><<</span>
</a>
</li>
<li><a href="#">1</a></li>
<li><a href="#">2</a></li>
<li><a href="#">3</a></li>
<li><a href="#">4</a></li>
<li><a href="#">5</a></li>
<li>
<a href="#" aria-label="Next">
<span aria-hidden="true">>></span>
</a>
</li>
</ul>
</nav>
{% endblock %}
{% block js %}
<script>
$('.delBtn').click(function () {
let isDel = confirm('你确定要删除吗?')
if(!isDel){
return false
}
})
</script>
{% endblock %}
bookEditPage.html:
{% extends 'homePage.html' %}
{% block content %}
<h2 class="text-center">书籍编辑页</h2>
<form action="" method="post">
<p>title:
<input type="text" name="title" class="form-control" value="{{ edit_obj.title }}">
</p>
<p>price:
<input type="text" name="price" class="form-control" value="{{ edit_obj.price }}">
</p>
<p>publish_time:
<input type="date" name="publish_time" class="form-control" value="{{ edit_obj.publish_time|date:'Y-m-d' }}">
</p>
<p>publish_name:
<!--展示系统中已有的出版社信息供选择-->
<select name="publish_id" id="" class="form-control">
{% for publish_obj in publish_queryset %} <!--queryset [数据对象 数据对象]-->
<!--根据待编辑的书籍对象查询对应的出版社 与系统所有的出版社比对 如果相同则添加默认选中的属性 selected-->
{% if edit_obj.publish == publish_obj %}
<option value="{{ publish_obj.pk }}" selected>{{ publish_obj.name }}</option>
{% else %}
<option value="{{ publish_obj.pk }}">{{ publish_obj.name }}</option>
{% endif %}
{% endfor %}
</select>
</p>
<p>author_list:
<!--展示系统中已有的作者信息供选择-->
<select name="author_id_list" id="" multiple class="form-control">
{% for author_obj in author_queryset %} <!--queryset [数据对象 数据对象]-->
<!--成员运算判断循环的作者对应是否在待编辑的书籍作者对象列表中-->
{% if author_obj in edit_obj.authors.all %}
<option value="{{ author_obj.pk }}" selected>{{ author_obj.name }}</option>
{% else %}
<option value="{{ author_obj.pk }}">{{ author_obj.name }}</option>
{% endif %}
{% endfor %}
</select>
</p>
<input type="submit" value="书籍编辑" class="btn btn-block btn-danger">
</form>
{% endblock %}
bookAddPage.html
{% extends 'homePage.html' %}
{% block content %}
<h2 class="text-center">图书添加页</h2>
<form action="" method="post">
<p>
title:
<input type="text" name="title" class="form-control">
</p>
<p>
price:
<input type="text" name="price" class="form-control">
</p>
<p>
publish_name:
<!--展示系统中的出版社信息供选择-->
<select name="publish_id" id="" class="form-control">
{% for publish_obj in publish_queryset %}
<option value="{{ publish_obj.pk }}">{{ publish_obj.name }}</option>
{% endfor %}
</select>
</p>
<p>
author_list:
<select name="author_id_list" id="" multiple class="form-control">
{% for author_obj in author_queryset %}
<option value="{{ author_obj.pk }}">{{ author_obj.name }}</option>
{% endfor %}
</select>
</p>
<input type="submit" value="书籍添加" class="btn btn-block btn-success" >
</form>
{% endblock %}
图书管理系统BMS的更多相关文章
- ORM练习项目-图书管理系统(BMS)实现细节
分析 一本书 可以由多个作者编著 一本书只能由一个出版社出版 一个作者可以写多本书 每个作者有自己的简介 对应关系: Author-Book # 多对多 Publish-Book # 一对多 Auth ...
- 11 基于django的图书管理系统 多表
1.需求 作业需求:1.列出图书列表.出版社列表.作者列表2.点击作者,会列出其出版的图书列表3.点击出版社,会列出旗下图书列表4.可以创建.修改.删除 图书.作者.出版社 踩分点:1.满足需求1,2 ...
- 基于jsp+servlet图书管理系统之后台万能模板
前奏: 刚开始接触博客园写博客,就是写写平时学的基础知识,慢慢发现大神写的博客思路很清晰,知识很丰富,非常又价值,反思自己写的,顿时感觉非常low,有相当长一段时间没有分享自己的知识.于是静下心来钻研 ...
- [入门级] 基于 visual studio 2010 mvc4 的图书管理系统开发初步 (二)
[入门级] 基于 visual studio 2010 mvc4 的图书管理系统开发初步 (二) Date 周六 10 一月 2015 By 钟谢伟 Category website develop ...
- 基于TXT文本的简单图书管理系统
1 ////////////////////////////////////////////////////////////////////////////////////// //SqList.h ...
- struts2+hibernate 项目实战:图书管理系统
经典项目,练手必备. 图书管理系统 需求分析(大致,并不专业):1.需要有用户管理: 1.1 用户注册: 1.2 用户登录: 1.3 用户信息修改: 1.4 用户修改密码: 2.需要有书本管理: 2. ...
- 图书管理系统——APP平台开发
http://www.w3school.com.cn/php/ 初步计划采用PHP 开发网站. 一定要独立建立一套图书管理系统, 尤其唯一性质的概念,整合,甚至中英文图书概念的而整合.一本书一个页. ...
- Java swing项目-图书管理系统(swing+mysql+jdbc)
(一)项目功能分析 该项目是设计一个图书管理系统,主要包含的内容有: (1)管理员登陆界面 ->信息录入 ->登录 ->重置 (2)图书管理系统总界面 ->子界面菜单: 1)图 ...
- 作业六—图书管理系统(SPEC)系统性能评估测试
一.图书管理系统的典型用户和场景: 该系统是为各类学校图书馆和社会各大图书馆和书店管理者使用的图书管理系统.但是我们还是已北京工业大学耿丹学院图书馆为典型用户进行主要设计的! 二.SPEC测试的目标: ...
- 基于jsp+servlet图书管理系统之后台用户信息查询操作
上一篇的博客写的是插入操作,且附有源码和数据库,这篇博客写的是查询操作,附有从头至尾写的代码(详细的注释)和数据库! 此次查询操作的源码和数据库:http://download.csdn.net/de ...
随机推荐
- 用 VS Code 搞 Qt6:信号、槽,以及QObject
Qt 里面的信号(Signal)和槽(Slot)虽然看着像事件,但它实际上是用来在两个对象之间进行通信的.既然是通信,就会有发送者和接收者. 1.信号是发送者,触发时通过特有的关键字"emi ...
- html页面跳转方式
js里的方法 第一种: window.location.href = XXXX; 第二种: window.setTimeout("javascript:location.href='xxxx ...
- 关于Intent.setDataAndType参数问题
关于Intent.setDataAndType参数问题 install取设置属于和类型,数据就是获取到的uri,更具文件类型不同,type参数也不相同,具体参考下表 {后缀名,MIME类型} {& ...
- 第2-3-6章 打包批量下载附件的接口开发-文件存储服务系统-nginx/fastDFS/minio/阿里云oss/七牛云oss
目录 5.6 接口开发-根据文件id打包下载附件 5.6.1 接口文档 5.6.2 代码实现 5.6.3 接口测试 5.7 接口开发-根据业务类型/业务id打包下载 5.7.1 接口文档 5.7.2 ...
- <二>自己实现简单的string
我们结合运算符重载知识实现string 类 在自己实现的String类中可以参考C++中string的方法 例如构造,加法,大小比较,长度,[] 等操作. 当前的MyString 类中,暂时不加入迭代 ...
- (C++) std::move std::forward及使用
概念 std::ref :针对std::thread,需要把实参显式转换为引用类型: std::move :无条件把参数转换为右值:但是右值赋值给新变量时,实际还要看是否满足右值条件,如const s ...
- Zookeeper的服务器的log4j升级为log4j2的升级方案(忽略配置化兼容问题)
参考在线markdown编辑器: http://marxi.co/ Zookeeper的服务器的log4j升级为log4j2的升级方案(忽略配置化兼容问题) 目前希望可以升级将Zookeeper中lo ...
- PostgreSQL常用操作合辑:时间日期、系统函数、正则表达式、库表导入导出、元数据查询、自定义函数、常用案例
〇.参考地址 1.pg官方文档 http://www.postgres.cn/docs/9.6/index.html 2.腾讯云仓pg文档 https://cloud.tencent.com/docu ...
- python 中文分词工具
python 中文分词工具 jieba,https://github.com/fxsjy/jieba jieba_fast,https://github.com/deepcs233/jieba_fas ...
- Blazor 部署 pdf.js 不能正确显示中文资源解决办法
在Blazor项目嵌入 pdf.js 时不能正确显示中文,浏览器F12显示如下错误 错误 l10n.js /web/locale/locale.properties not found. 我找到了解决 ...