出版社的增删改查

 展示出版社列表:

  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' 表示当还未进行信息编辑时,需要先跳转到编辑页面,依照选定好的对

        象进行信息的编辑,编辑完成后,提交.

    

    创建编辑页面:

    

  作者的曾删改查(多对多)

    作者可以写多本书,一本书也可以有多个作者.

    创建作者和书的关系

      方法一:        

  1. # 作者:
  2. class Author(models.Model):
  3. id = models.AuthorField(primary_key=True) # 自增id主键
  4. name = models.CharField(max_length=32) # 作者名字
  5.  
  6. # 创建作者和书籍的关系表
  7. class Author2Book(models.Model):
  8. id = models.AuthorField(primary_key=True)
  9. author = models.Foreignkey(to='Author', on_delete=models.CASCADE)
  10. book = models.Foreignkey(to='Book', on_delete=models.CASCADE)

      方法二 (用orm创建)    

  1. class Author(models.Model):
  2. id = models.AuthorField(primary_key=True) # 自增id主键
  3. name = models.CharField(max_length=32) # 作者名字
  4. 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页面      

  1.      enctype="multipart/form-data" 是文件操作必须要有的

    

    

    

    

    

  

  

Django之图书管理系统的更多相关文章

  1. 11 基于django的图书管理系统 多表

    1.需求 作业需求:1.列出图书列表.出版社列表.作者列表2.点击作者,会列出其出版的图书列表3.点击出版社,会列出旗下图书列表4.可以创建.修改.删除 图书.作者.出版社 踩分点:1.满足需求1,2 ...

  2. Python高级进阶(二)Python框架之Django写图书管理系统(LMS)

    正式写项目准备前的工作 Django是一个Web框架,我们使用它就是因为它能够把前后端解耦合而且能够与数据库建立ORM,这样,一个Python开发工程师只需要干自己开发的事情就可以了,而在使用之前就我 ...

  3. Django练习——图书管理系统

    Django图书管理系统 创建一个项目 1. django-admin startproject 图书管理 2. cmd 命令终端下创建一个app python manage.py startapp ...

  4. Django(图书管理系统)

    图书管理系统 注意事项 1.models 要创建好,规划好自己的表,以及各种表关系 2.url正则要写好 3.settings的配置 4.利用bootstarp 进行布局更漂亮哦 5.注意orm  各 ...

  5. Django学习——图书管理系统图书修改、orm常用和非常用字段(了解)、 orm字段参数(了解)、字段关系(了解)、手动创建第三张表、Meta元信息、原生SQL、Django与ajax(入门)

    1 图书管理系统图书修改 1.1 views 修改图书获取id的两种方案 1 <input type="hidden" name="id" value=& ...

  6. Django(图书管理系统)#转

    自己虽然实现了, 但是写的太LOW了,为了不误导大家,推荐一篇好的博客 https://www.cnblogs.com/alice-bj/p/9114084.html

  7. Django——图书管理系统

    基于Django的图书管理系统 1.主体功能 1.列出图书列表.出版社列表.作者列表 2.点击作者,会列出其出版的图书列表 3.点击出版社,会列出旗下图书列表 4.可以创建.修改.删除 图书.作者.出 ...

  8. Django实现简单的图书管理系统

    目录 Django写图书管理系统 功能截图 创建Django项目 开始项目 配置文件 建立路由关系 开始写Django项目 编写核心逻辑函数 写前端页面 add_author.html add_boo ...

  9. 在Django中使用ORM创建图书管理系统

    一.ORM(对象关系映射) 很多语言的web框架中都有这个概念 1. 为什么要有ORM? 1. 写程序离不开数据,要使用数据就需要连接数据库,但是不同的数据库在sql语句上(mysql,oracle等 ...

随机推荐

  1. QT的定时器使用

    http://blog.csdn.net/steven6977/article/details/9310997

  2. 二阶SQL注入理解与体会

    一:SQL注入分类 SQL注入一般分为两类:一阶SQL注入(普通SQL注入),二阶SQL注入 二:二者进行比较 0x01:一阶SQL注入: 1:一阶SQL注入发生在一个HTTP请求和响应中,对系统的攻 ...

  3. 设置dedecms标签 [field:global.autoindex/] 初始值{class递增}

    在{dede:arclist/}这个标签中有个[field:global.autoindex/],是从0开始自增,如果我们想自定义一个数值,比如自定义从2开始.那么就可以写成下面代码: [field: ...

  4. rolllup巧用

    --构造环境drop table dept purge;drop table emp purge;create table dept as select * from scott.dept;creat ...

  5. vim使用常看

    原网址http://www.runoob.com/linux/linux-vim.html 补充参考https://blog.csdn.net/w178191520/article/details/8 ...

  6. WebSphere Studio Application Developer 5.0 优化设置

    公司有一个项目需要用到WebSphere Studio Application Developer 5.0 的开发环境,这个环境比较老,而且只能用JDK1.4. 项目开发的时候 总是报错: JVM t ...

  7. web项目脱离Eclipse在Tomcat部署并配置Eclipse调试

    简单来说,把WEB项目打成war包后放到webapps目录下启动tomcat便部署成功了,但是因为与Eclipse没有关联,故而无法Debug调试代码.这时在Tomcat的catalina.sh脚本里 ...

  8. AWESOME SWIFT-swift.libhunt.com-swift类库网站

    https://swift.libhunt.com/categories/688-events 29 Events libraries and projects ORDERED BY POPULARI ...

  9. 完整详解GCD系列(三)dispatch_group

    http://blog.csdn.net/hello_hwc/article/details/41409135 一.dispatch_group把一组任务提交到队列中,这些队列可以不相关,然后坚挺这组 ...

  10. UVa 1636 - Headshot(概率)

    链接: https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem& ...