• 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)
    

      

      

  • 相关阅读:
    学习Py——自己模拟写的一个Range功能
    心情随笔20180529
    记一次排查局网内的ARP包 “不存在的” MAC 地址及 “不存在的”IP 所发的ARP包
    最长反链
    浅谈矩阵树定理
    毒瘤dp 学校食堂
    P3565 由简单的树形dp 引入 长链刨分
    noi 2017 整数
    记人生的抉择
    2019 HL SC day10
  • 原文地址:https://www.cnblogs.com/mike-liu/p/9637161.html
Copyright © 2020-2023  润新知