一、添加表记录
对于单表有两种方式
方式一:
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() 方法导致 所有的 记录被误删除。如果你确认要删除所有的对象,那么你必须显式地调用:
五、编辑表格中的内容的涉及到的语法
编辑操作涉及到的语法
分析:
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)