Django之图书管理系统
出版社的增删改查
展示出版社列表:
1. 创建一个表结构:

2. 再配合那俩条命令即可创建一个press表

创建出版社函数,并在url中进行配置

创建HTML页面,展示出版社的表
for循环
{% for i in ret %} ---- 模板语言
i 指的是 从 ret 中拿到的对象
{{ forloop.counter }} --> for循环从1开始计数
{{ forloop.counter0 }} --> for循环从0开始计数
{% endfor %}

添加出版社(在原表中添加)
要添加出版社,先跳转到添加页面,
创建添加出版社函数(在url中配置好):

创建添加页面
把页面输入的信息以post的方式提交一个字典,封装到name键
值中,最终传给press_add

添加完成并展示:

还可以在出版社列表页面建立 a 标签,点击即可跳转添加页面

删除出版社:
在出版社列表中添加删除操作,点击删除项,把要删除的该项在数据库
中删除.
在出版社列表的html页面中标明点击''删除''请求后,接收请求的对象.

创建删除出版社的函数:
即创建接收请求的函数,对该请求做出处理.

编辑出版社
修改原有出版社的信息,在原有列表上添加'编辑'选项,点击该选项
跳转到编辑页面.
创建编辑出版社的函数(并完成配置)
在函数中修改并同步数据库

创建编辑的HTML页面

图书的增删改查
在数据库中创建图书的列表:
在models中创建图书的表结构的类
通过那俩个命令在数据库中创建表

创建对书列表进行操作的函数(并在url中配置好)

创建在前端展示的html页面


注意: 在函数中对表进行操作,需要通过ORM语言编写的表结构类,来获
取表的信息

输出的Press object 对象是通过外键获取的出版社对象
还可以打印出出版社名字: print(data[0].press.name)


此外 data[0].press_id 可以查询到与这本书相关联的出版社id 是通过外键查询的,在
类中创建表结构过程中,创建外键会自动在数据库中创建外键关联id,此时的外
键id就在本表中.

data[0].press.id 也可以查询到与这本书相关联的出版社id 是通过连表查询的,
.press是出版社的对象, .id自然能够获取到与data[0]相关的出版社id.
添加书籍
创建添加书籍的操作函数(在url中配置好)

(注意: 上图name错误,表结构中 书籍的名字标题是title)
创建添加页面

删除书籍
在书籍列表中添加删除操作项,点击操作项跳转带删除函数进行删除操作.
创建要删除书籍的操作函数

编辑书籍
在书籍页面中,添加编辑操作的选项,选中要编辑的书籍对象,跳转页面进
行修改,然后保存.
创建编辑书籍的操作函数(并配置好):

注意 : 末尾的 'return' 表示当还未进行信息编辑时,需要先跳转到编辑页面,依照选定好的对
象进行信息的编辑,编辑完成后,提交.
创建编辑页面:

作者的曾删改查(多对多)
作者可以写多本书,一本书也可以有多个作者.
创建作者和书的关系
方法一:
# 作者:
class Author(models.Model):
id = models.AuthorField(primary_key=True) # 自增id主键
name = models.CharField(max_length=32) # 作者名字 # 创建作者和书籍的关系表
class Author2Book(models.Model):
id = models.AuthorField(primary_key=True)
author = models.Foreignkey(to='Author', on_delete=models.CASCADE)
book = models.Foreignkey(to='Book', on_delete=models.CASCADE)
方法二 (用orm创建)
class Author(models.Model):
id = models.AuthorField(primary_key=True) # 自增id主键
name = models.CharField(max_length=32) # 作者名字
books = models.ManyToManyField(to='Book')

查询 在数据库中找到所有作者信息,然后在页面展示出来
创建作者函数并配置好


创建html文件在页面上展示出来


添加 创建添加操作的函数,展示添加页面,获取用户的添加信息,返回给
数据库,再展示作者信息.
创建添加操作的函数,并配置好

创建获取信息的页面

删除和编辑
在作者列表中添加删除操作项,锁定要删除的对象,

创建要删除的操作函数,

在作者列表中添加编辑操作,锁定要编辑的对象

创建编辑函数,并配置好:

创建html页面,展示编辑页面并获取用户填写的信息

注意: 模板语言, in 判断 {% if book in author.books.all %} 意为该
书在作者所关联的书籍列表中的话.
ORM 编辑多对多不能直接编辑第三张表,要借助ORM提供的方法:
all() ; add(id1, id2); set([id1, id2]); clear()清空
上传文件
创建上传文件的操作函数,并配置好


创建上传文件的html页面
enctype="multipart/form-data" 是文件操作必须要有的

Django之图书管理系统的更多相关文章
- 11 基于django的图书管理系统 多表
1.需求 作业需求:1.列出图书列表.出版社列表.作者列表2.点击作者,会列出其出版的图书列表3.点击出版社,会列出旗下图书列表4.可以创建.修改.删除 图书.作者.出版社 踩分点:1.满足需求1,2 ...
- Python高级进阶(二)Python框架之Django写图书管理系统(LMS)
正式写项目准备前的工作 Django是一个Web框架,我们使用它就是因为它能够把前后端解耦合而且能够与数据库建立ORM,这样,一个Python开发工程师只需要干自己开发的事情就可以了,而在使用之前就我 ...
- Django练习——图书管理系统
Django图书管理系统 创建一个项目 1. django-admin startproject 图书管理 2. cmd 命令终端下创建一个app python manage.py startapp ...
- Django(图书管理系统)
图书管理系统 注意事项 1.models 要创建好,规划好自己的表,以及各种表关系 2.url正则要写好 3.settings的配置 4.利用bootstarp 进行布局更漂亮哦 5.注意orm 各 ...
- Django学习——图书管理系统图书修改、orm常用和非常用字段(了解)、 orm字段参数(了解)、字段关系(了解)、手动创建第三张表、Meta元信息、原生SQL、Django与ajax(入门)
1 图书管理系统图书修改 1.1 views 修改图书获取id的两种方案 1 <input type="hidden" name="id" value=& ...
- Django(图书管理系统)#转
自己虽然实现了, 但是写的太LOW了,为了不误导大家,推荐一篇好的博客 https://www.cnblogs.com/alice-bj/p/9114084.html
- Django——图书管理系统
基于Django的图书管理系统 1.主体功能 1.列出图书列表.出版社列表.作者列表 2.点击作者,会列出其出版的图书列表 3.点击出版社,会列出旗下图书列表 4.可以创建.修改.删除 图书.作者.出 ...
- Django实现简单的图书管理系统
目录 Django写图书管理系统 功能截图 创建Django项目 开始项目 配置文件 建立路由关系 开始写Django项目 编写核心逻辑函数 写前端页面 add_author.html add_boo ...
- 在Django中使用ORM创建图书管理系统
一.ORM(对象关系映射) 很多语言的web框架中都有这个概念 1. 为什么要有ORM? 1. 写程序离不开数据,要使用数据就需要连接数据库,但是不同的数据库在sql语句上(mysql,oracle等 ...
随机推荐
- 【Leetcode】【Medium】Sum Root to Leaf Numbers (未完成)
Given a binary tree containing digits from 0-9 only, each root-to-leaf path could represent a number ...
- windows10 蓝牙(Bluetooth®)设备删除失败解决方案
某次更新后蓝牙鼠标突然断线无响应,于是尝试删除设备后重新配对,但是出现了删除失败: 这时候可以这样解决: 进入设备管理器(Win+X 设备管理器) 点击 查看 (在最上面一行),选择"显示隐 ...
- [原]零基础学习SDL开发之在Android使用SDL2.0渲染PNG图片
在上一篇文章我们知道了如何在android使用SDL2.0来渲染显示一张bmp图,但是如果是一张png或者一张jpg的图,那么还能显示成功么?答案是否定的 我们需要移植SDL_image库来支持除bm ...
- scanf函数读取缓冲区数据的问题
标准I\O的缓冲类型 标准I\O根据不同的应用需求,提供了全缓冲.行缓冲.无缓冲三种缓冲方式. 全缓冲:只有当划定的缓冲区被填满或者数据读取至末尾时,才开始执行I\O操作(执行系统提供的read\wr ...
- 解决Ubuntu启动错误——kernel panic not syncing vfs unable to mount root fs on unknown-block 0 0 – error
最近在倒腾Ubuntu,然后想着怎么美化一下界面,于是照着网上的教程整了一下Flatabulous这个软件,然后好像/boot就满了.关机之后再开机就出现了如题所述的错误,无法开机,也无法进入reco ...
- servlet的使用
Servlet是比较基础的的客户端与服务器数据交互程序,通过HttpServletRequest请求和HttpServletResponse响应,可以基本实现web程序开发. 1.Servlet基础代 ...
- Android进阶笔记14:3种JSON解析工具(org.json、fastjson、gson)
一. 目前解析json有三种工具:org.json(Java常用的解析),fastjson(阿里巴巴工程师开发的),Gson(Google官网出的),其中解析速度最快的是Gson. 3种json工具下 ...
- 关于映射异常org.hibernate.MappingException: An association from the table DUTY_INFO refers to an unmapped class: com.pms.entities.other.Department的原因。
在编程过程当中由于修改过了包名. 原来的包名是: com.pms.entities.base 然后改为了:com.pms.entities.other 当我重新映射生成数据表的时候就报错:org.hi ...
- 剑指offer 14 调整数组顺序使奇数位于偶数前面
牛客网上的题目还有一个额外的要求,就是不改变数组原始的前后数据,这种可以用队列来存储,或者把前后比较变为相邻的元素比较. 这个题目,主要要考察扩展性,用func函数就实现了扩展性.只需要改func函数 ...
- Learning by doing——获黄色领骑衫之感
获奖感言 能拿到这件黄色的领骑衫,心里真的非常高兴.仔细看了一下,扣子.领子.各种图案各种细节十分精致.可以说这件领骑衫既有纪念意义,又有实用意义,真的很棒. 背后的故事 其实开始接触博客的时候,我是 ...