一、添加表记录
对于单表有两种方式
方式一:
book_obj=models.Book(title="python全栈开发",price=100,publishData="2015-08-08", author='张三', publish='机械工业出版社') book_obj.save()
方式二:
# 方式二: models.Book.objects.create(title="java全栈开发",price=150,publishData="2018-08-08", author='李四', publish='人民出版社')
二、查询表记录
查询相关API
# 1、all():查看所有 book_obj = models.Book.objects.all() print(book_obj) # 打印的结果是QuerySet集合:<QuerySet [<Book: python全栈开发>, <Book: java全栈开发>]> # 2、filter(): 可以实现且关系,但是或关系需要借助Q查询实现 # 查不到的时候不会报错 print(models.Book.objects.filter(title="python全栈开发")) # 查询书名为“python全栈开发” print(models.Book.objects.filter(price="100", author="张三")) # 3、get():如果找不到就会报错,如果有多个值,也会报错,只能拿一个值 print(models.Book.objects.get(title="python全栈开发")) # 拿的是model对象 # 4、exclude():排除条件 print(models.Book.objects.exclude(title="python全栈开发")) # 查看除了书名是"python全栈开发"的信息 # 结果:<QuerySet [<Book: java全栈开发>, <Book: PHP全栈开发>, <Book: PHP全栈开发>, <Book: PHP全栈开发>, <Book: PHP全栈开发>]> # # 5、values():是queryset的一个方法(把对象转换成字典的形式) print(models.Book.objects.filter(title="python全栈开发").values("publish", "author")) # 查看书名为“Python全栈开发”的出版社和作者 # 结果:<QuerySet [{'publish': '机械工业出版社', 'author': '张三'}]> # 6、values_list():是queryset的一个方法(把对象转成元组形式) print(models.Book.objects.filter(title="python全栈开发").values_list("publish", "author")) # <QuerySet [('机械工业出版社', '张三')]> # 7、order_by():排序 print(models.Book.objects.all().order_by("id")) # # 8、reverse():倒序 print(models.Book.objects.all().reverse()) # # 9、distinct():去重(只要结果里面有重复的) print(models.Book.objects.filter(title="PHP全栈开发").values("price").distinct()) # 结果:<QuerySet [{'price': Decimal('100.00')}]> # # 10、count():查看有几条记录 print(models.Book.objects.filter(title="PHP全栈开发").count()) # # 11、first():返回第一条记录 print(models.Book.objects.all().first()) # 12、last():返回最后一条记录 print(models.Book.objects.all().last()) # 13、esits:查看有没有记录, 如果有返回True,没有返回False # 并不需要判断所有的数据 if models.Book.objects.all().exists(): print('ok')
查询表记录—模糊查询
ret=models.Book.objects.filter(price__gt=50, price__lt=150) # 查询价格在50到150之间的书籍信息 print(ret) ret = models.Book.objects.filter(price__in=[100, 250, 300]) # 查询价格等于100,250,300的数据 print(ret) ret = models.Book.objects.filter(title__startswith='p') # 以“p”开头的书名 print(ret) ret = models.Book.objects.filter(title__contains='y') # 包括“y”的书名 print(ret) ret = models.Book.objects.filter(title__icontains='p') # 不区分大小写 print(ret) ret = models.Book.objects.filter(publishData__year=2018, publishData__month=8) # 出版年月为2018年8月的 print(ret)
三、修改表记录:
ret = models.Book.objects.filter(title="PHP全栈开发").update(title="测试开发全栈开发") print(ret)
四、删除表记录
删除方法就是delete(),它运行时立即删除对象不返回任何值。
ret = models.Book.objects.filter(id="73").delete() print(ret) ret = models.Book.objects.filter(id="73").first().delete()
你也可以一次性删除多个对象。每个QuerySet都有一个delete()方法,它一次性删除QuerySet中所有的对象。
例如,下面的代码将删除publishData是2018年的对象
Entry.objects.filter(publishData__year=2018).delete()
要牢记这一点:无论在什么情况下,QuerySet 中的 delete() 方法都只使用一条 SQL 语句一次性删除所有对象,而并不是分别删除每个对象。如果你想使用在 model 中自定义的 delete() 方法,就要自行调用每个对象的delete 方法。(例如,遍历 QuerySet,在每个对象上调用 delete()方法),而不是使用 QuerySet 中的 delete()方法。
在 Django 删除对象时,会模仿 SQL 约束 ON DELETE CASCADE 的行为,换句话说,删除一个对象时也会删除与它相关联的外键对象。例如:
b = Blog.objects.get(pk=1) # This will delete the Blog and all of its Entry objects. b.delete()
要注意的是: delete() 方法是 QuerySet 上的方法,但并不适用于 Manager 本身。这是一种保护机制,是为了避免意外地调用 Entry.objects.delete() 方法导致 所有的 记录被误删除。如果你确认要删除所有的对象,那么你必须显式地调用:
Entry.objects.all().delete()
五、编辑表格中的内容的涉及到的语法
编辑操作涉及到的语法 分析: 1、点击编辑,让跳转到另一个页面,拿到我点击的那一行 两种取id值的方式 方式一: 利用数据传参数(作为数据参数传过去) <a href="/edit/?book_id={{book_obj.id}}"></a> # 相当于发了一个键值对 URL里面就不用写匹配的路径了,id=request.GET.get("book_id") # 取值 方式二: 利用路径传参,得在URL里面加上(d+),就得给函数传个参数,无名分组从参数里面取值 <a href="/{{book_obj.id}}"></a> 2、拿到id,然后再做筛选 id = request.GET.get("book_id") book_obj=models.Book.objects.filter(id=id) # 拿到的是一个列表对象 注意: 1.取[0]就拿到对象了,然后对象.属性就可以取值了 2.用get,你取出来的数据必须只有一条的时候, 如果有多条用get就会报错,但是用get就不用加[0]了 book_obj=models.Book.objects.filter(id=id)[0] 3、当点击编辑的时候怎么让input框里显示文本内容 value=“{{book_obj.title}}" 4、改完数据后重新提交 当提交的时候走action..../edit/} 隐藏一个input <input type="hidden" name="book_id" value="{{book_obj.id}}"> 判断post的时候 修改数据: 方式一:save(这种方式效率是非常低的,不推荐使用,了解就行了) 修改的前提是先取(拿到要编辑的id值) id = request.POST.get("book_id") bk_obj = models.Book.objects.filter(nid=id)[0] bk_obj.title = "hhhhhh" #这是写死了,不能都像这样写死了 bk_obj.save() 只要是用对象的这种都要.save 方式二:update title = request.POST.get("title") models.Book.objects.filter(nid=id).update(title=title,......) 跳转到index 如果是post请求的时候怎么找到id呢, 一、如果是数据传参:(也就是get请求的时候) 可以通过一个隐藏的input框,给这个框给一个name属性,value属性。通过request.POST.get("键"),,就可以得到id的值 二、如果是路径传参 可以通过传参的形式,当正则表达式写一个(d+)的时候,就给函数传一个id,可通过这个id知道id.
章节作业
1、图书管理系统
实现功能:book单表的增删改查
views.py
from django.http import HttpResponse from django.shortcuts import render, redirect # Create your views here. from app01 import models def addbook(request): if request.method == "POST": title = request.POST.get("title") date = request.POST.get("date") author = request.POST.get("author") price = request.POST.get("price") publish = request.POST.get("publish") book_obj = models.Book.objects.create(title=title, publish=publish, publishData=date, author=author, price=price) return redirect("/books") return render(request, "addbook.html") def books(request): book_list=models.Book.objects.all() return render(request, "books.html", locals()) def changebook(request, id): book_obj = models.Book.objects.filter(id=id).first() if request.method == "POST": title = request.POST.get("title") date = request.POST.get("date") author = request.POST.get("author") price = request.POST.get("price") publish = request.POST.get("publish") models.Book.objects.filter(id=id).update(title=title, publishData=date, author=author, price=price, publish=publish) return redirect("/books") return render(request, "changebook.html", {"book_obj": book_obj}) def delbook(request, id): models.Book.objects.filter(id=id).delete() return redirect("/books")
addbook.html
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>添加图书</title> <link rel="stylesheet" href="/static/bootstrap-3.3.7/css/bootstrap.min.css"> <script src="/static/bootstrap-3.3.7/js/bootstrap.min.js"></script> <style> .container{ margin-top: 100px; } .btn{ margin-top: 10px; } </style> </head> <body> <h3>添加书籍</h3> <div class="container"> <div class="row"> <div class="col-md-6 col-md-off-3"> <form action="" method="post"> {% csrf_token %} <div> <label for="">书籍名称</label> <input type="text" class="form-control" name="title"> </div> <div> <label for="">作者</label> <input type="text" class="form-control" name="author"> </div> <div> <label for="">价格</label> <input type="text" class="form-control" name="price"> </div> <div> <label for="">出版日期</label> <input type="date" class="form-control" name="date"> </div> <div> <label for="">出版社</label> <input type="text" class="form-control" name="publish"> </div> <input type="submit" class="btn btn-sucess pull-right"> </form> </div> </div> </div> </body> </html>
books.html
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>图书列表</title> <link rel="stylesheet" href="/static/bootstrap-3.3.7/css/bootstrap.min.css"> <script src="/static/bootstrap-3.3.7/js/bootstrap.min.js"></script> <style> .container{ margin-top: 100px; } .btn{ margin-top: 10px; } </style> </head> <body> <h3>查看书籍</h3> <div class="container"> <div class="row"> <div class="col-md-6 col-md-offset-3"> <a href="/addbook" class="btn btn-primary">添加书籍</a> <table class="table table-striped table-bordered"> <thead> <tr> <th>书籍名称</th> <th>作者</th> <th>价格(元)</th> <th>出版社</th> <th>出版日期</th> <th>操作</th> </tr> </thead> <tbody> {% for book in book_list %} <tr> <td>{{ book.title }}</td> <td>{{ book.author}}</td> <td>{{ book.price }}</td> <td>{{ book.publish }}</td> <td>{{ book.publishData|date:'Y-m-d' }}</td> <td> <a href="/books/{{ book.pk }}/delete"><button class="btn btn-danger">删除</button></a> <a href="/books/{{ book.pk }}/change"><button class="btn btn-info">编辑</button></a> </td> </tr> {% endfor %} </tbody> </table> </div> </div> </div> </body> </html>
changebook.html
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>编辑书籍</title> <link rel="stylesheet" href="/static/bootstrap-3.3.7/css/bootstrap.min.css"> <script src="/static/bootstrap-3.3.7/js/bootstrap.min.js"></script> <style> .container{ margin-top: 100px; } .btn{ margin-top: 10px; } </style> </head> <body> <h3>编辑书籍</h3> <div class="container"> <div class="row"> <div class="col-md-6 col-md-offset-3"> <form action="" method="post"> {% csrf_token %} <div> <label for="">书籍名称</label> <input type="text" class="form-control" name="title" value="{{ book_obj.title }}"> </div> <div> <label for="">作者</label> <input type="text" class="form-control" name="author" value="{{ book_obj.author }}"> </div> <div> <label for="">价格(元)</label> <input type="text" class="form-control" name="price" value="{{ book_obj.price }}"> </div> <div> <label for="">出版社</label> <input type="text" class="form-control" name="publish" value="{{ book_obj.publish }}"> </div> <div> <label for="">出版日期</label> <input type="date" class="form-control" name="date" value="{{ book_obj.publishData|date:'Y-m-d' }}"> </div> <input type="submit" class="btn btn-success pull-right"> </form> </div> </div> </div> </body> </html>
2、查询操作练习
book_obj = models.Book.objects.filter(publish="老男孩出版社", price__gt=200) print(book_obj) # 2、查询2017年8月出版的所有以py开头的书籍名称 book_obj = models.Book.objects.filter(publishData__year=2017, publishData__month=8, title__startswith='Py').values("title") print(book_obj) # 3、查询价格为50, 100 或者150的所有书籍名称及其出版社名称 book_obj = models.Book.objects.filter(price__in=[50, 100, 150]).values("title", "publish") print(book_obj) # 4、查询价格在100到200之间的所有书籍名称及其价格 book_obj = models.Book.objects.filter(price__gt=100, price__lt=200).values("title", "price") print(book_obj) # 查询所有人民出版社出版的书籍的价格(从高到低排序,去重) book_obj = models.Book.objects.filter(publish="人民出版社").values("price").distinct().order_by("-price") print(book_obj)