Web框架开发-Django-数据库表的单表查询

一、添加表记录

对于单表有两种方式

方式一:

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)

  

  

原文地址:https://www.cnblogs.com/mike-liu/p/9637161.html