出版社的增删改查html
展现出版社列表: 前端
1. 建立一个表结构:数据库
2. 再配合那俩条命令便可建立一个press表函数
建立出版社函数,并在url中进行配置oop
建立HTML页面,展现出版社的表post
for循环url
{% for i in ret %} ---- 模板语言
i 指的是 从 ret 中拿到的对象
{{ forloop.counter }} --> for循环从1开始计数
{{ forloop.counter0 }} --> for循环从0开始计数
{% endfor %}spa
添加出版社(在原表中添加)3d
要添加出版社,先跳转到添加页面,code
建立添加出版社函数(在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" 是文件操做必需要有的