首页 > 其他分享 >Django ORM - 单表实例

Django ORM - 单表实例

时间:2024-12-16 19:59:19浏览次数:11  
标签:objects models ORM Django Book books 单表 import app01

创建一个项目 app01(如果之前已创建过,忽略以下操作):

django-admin.py startproject app01

接下来在 settings.py 中找到 INSTALLED_APPS 这一项,如下:

INSTALLED_APPS = (
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'app01',               # 添加此项
)

接下来,告诉 Django 使用 pymysql 模块连接 mysql 数据库:

实例

# 在与 settings.py 同级目录下的 __init__.py 中引入模块和进行配置 
import pymysql
pymysql.install_as_MySQLdb()

创建模型

在项目中的 models.py 中添加以下类:

app01/models.py

class Book(models.Model): 
    id = models.AutoField(primary_key=True) # id 会自动创建,可以手动写入
    title = models.CharField(max_length=32) # 书籍名称
    price = models.DecimalField(max_digits=5, decimal_places=2) # 书籍价格 
    publish = models.CharField(max_length=32) # 出版社名称 
    pub_date = models.DateField() # 出版时间

然后在命令行执行以下命令:

$ python3 manage.py migrate   # 创建表结构

$ python3 manage.py makemigrations app01  # 让 Django 知道我们在我们的模型有一些变更
$ python3 manage.py migrate app01   # 创建表结构

常见报错信息

如果执行以上命令时会出现如下报错信息:

原因是 MySQLclient 目前只支持到 Python3.4,因此如果使用的更高版本的 python,需要修改如下:

通过报错信息的文件路径找到 ...site-packages\Django-2.0-py3.6.egg\django\db\backends\mysql 这个路径里的 base.py 文件,把这两行代码注释掉(代码在文件开头部分):

if version < (1, 3, 13):
    raise ImproperlyConfigured('mysqlclient 1.3.13 or newer is required; you have %s.' % Database.__version__)

一般点报错的代码文件路径信息,会自动跳转到报错文件中行数,此时我们在报错的代码行数注释掉。

这时数据库 runoob 就会创建一个 app01_book 的表。

接下来我们在app01 项目里添加 views.py 和 models.py 文件,app01 项目目录结构:

app01
|-- app01
|   |-- __init__.py
|   |-- __pycache__
|   |-- asgi.py
|   |-- migrations
|   |-- models.py
|   |-- settings.py
|   |-- urls.py
|   |-- views.py
|   `-- wsgi.py

数据库添加

规则配置:

app01/urls.py: 文件代码:

from django.contrib import admin from django.urls import path from . import views urlpatterns = [ path('add_book/', views.add_book), ]

方式一:模型类实例化对象

需从 app 目录引入 models.py 文件:

from app 目录 import models

并且实例化对象后要执行 对象.save() 才能在数据库中新增成功。

app01/views.py: 文件代码:

from django.shortcuts import render,HttpResponse from app01 import models def add_book(request): book = models.Book(title="菜鸟教程",price=300,publish="菜鸟出版社",pub_date="2008-8-8") book.save() return HttpResponse("<p>数据添加成功!</p>")

方式二:通过 ORM 提供的 objects 提供的方法 create 来实现(推荐)

app01/views.py: 文件代码:

from django.shortcuts import render,HttpResponse from app01 import models def add_book(request): books = models.Book.objects.create(title="如来神掌",price=200,publish="功夫出版社",pub_date="2010-10-10") print(books, type(books)) # Book object (18) return HttpResponse("<p>数据添加成功!</p>")

查找

使用 all() 方法来查询所有内容。

返回的是 QuerySet 类型数据,类似于 list,里面放的是一个个模型类的对象,可用索引下标取出模型类的对象。

app01/views.py: 文件代码:

from django.shortcuts import render,HttpResponse from app01 import models def add_book(request): books = models.Book.objects.all() print(books,type(books)) # QuerySet类型,类似于list,访问 url 时数据显示在命令行窗口中。 return HttpResponse("<p>查找成功!</p>")

filter() 方法用于查询符合条件的数据。

返回的是 QuerySet 类型数据,类似于 list,里面放的是满足条件的模型类的对象,可用索引下标取出模型类的对象。

pk=3 的意思是主键 primary key=3,相当于 id=3。

因为 id 在 pycharm 里有特殊含义,是看内存地址的内置函数 id(),因此用 pk。

app01/views.py: 文件代码:

from django.shortcuts import render,HttpResponse from app01 import models def add_book(request): books = models.Book.objects.filter(pk=5) print(books) print("//") books = models.Book.objects.filter(publish='菜鸟出版社', price=300) print(books, type(books)) # QuerySet类型,类似于list。 return HttpResponse("<p>查找成功!</p>")

exclude() 方法用于查询不符合条件的数据。

返回的是 QuerySet 类型数据,类似于 list,里面放的是不满足条件的模型类的对象,可用索引下标取出模型类的对象。

app01/views.py: 文件代码:

from django.shortcuts import render,HttpResponse from app01 import models def add_book(request): books = models.Book.objects.exclude(pk=5) print(books) print("//") books = models.Book.objects.exclude(publish='菜鸟出版社', price=300) print(books, type(books)) # QuerySet类型,类似于list。 return HttpResponse("<p>查找成功!</p>")

get() 方法用于查询符合条件的返回模型类的对象符合条件的对象只能为一个,如果符合筛选条件的对象超过了一个或者没有一个都会抛出错误。

app01/views.py: 文件代码:

from django.shortcuts import render,HttpResponse from app01 import models def add_book(request): books = models.Book.objects.get(pk=5) books = models.Book.objects.get(pk=18) # 报错,没有符合条件的对象 books = models.Book.objects.get(price=200) # 报错,符合条件的对象超过一个 print(books, type(books)) # 模型类的对象 return HttpResponse("<p>查找成功!</p>")

order_by() 方法用于对查询结果进行排序。

返回的是 QuerySet类型数据,类似于list,里面放的是排序后的模型类的对象,可用索引下标取出模型类的对象。

注意:

  • a、参数的字段名要加引号。
  • b、降序为在字段前面加个负号 -。

app01/views.py: 文件代码:

from django.shortcuts import render,HttpResponse from app01 import models def add_book(request): books = models.Book.objects.order_by("price") # 查询所有,按照价格升序排列 books = models.Book.objects.order_by("-price") # 查询所有,按照价格降序排列 return HttpResponse("<p>查找成功!</p>")

reverse() 方法用于对查询结果进行反转。

返回的是 QuerySe t类型数据,类似于 list,里面放的是反转后的模型类的对象,可用索引下标取出模型类的对象。

app01/views.py: 文件代码:

from django.shortcuts import render,HttpResponse from app01 import models def add_book(request): # 按照价格升序排列:降序再反转 books = models.Book.objects.order_by("-price").reverse() return HttpResponse("<p>查找成功!</p>")

count() 方法用于查询数据的数量返回的数据是整数。

app01/views.py: 文件代码:

from django.shortcuts import render,HttpResponse from app01 import models def add_book(request): books = models.Book.objects.count() # 查询所有数据的数量 books = models.Book.objects.filter(price=200).count() # 查询符合条件数据的数量 return HttpResponse("<p>查找成功!</p>")

first() 方法返回第一条数据返回的数据是模型类的对象也可以用索引下标 [0]。

app01/views.py: 文件代码:

from django.shortcuts import render,HttpResponse from app01 import models def add_book(request): books = models.Book.objects.first() # 返回所有数据的第一条数据 return HttpResponse("<p>查找成功!</p>")

last() 方法返回最后一条数据返回的数据是模型类的对象不能用索引下标 [-1],ORM 没有逆序索引。

app01/views.py: 文件代码:

from django.shortcuts import render,HttpResponse from app01 import models def add_book(request): books = models.Book.objects.last() # 返回所有数据的最后一条数据 return HttpResponse("<p>查找成功!</p>")

exists() 方法用于判断查询的结果 QuerySet 列表里是否有数据。

返回的数据类型是布尔,有为 true,没有为 false。

注意:判断的数据类型只能为 QuerySet 类型数据,不能为整型和模型类的对象。

实例

from django.shortcuts import render,HttpResponse
from app01 import models 
def add_book(request):
    books = models.Book.objects.exists() 
    # 报错,判断的数据类型只能为QuerySet类型数据,不能为整型 
    books = models.Book.objects.count().exists()
    # 报错,判断的数据类型只能为QuerySet类型数据,不能为模型类对象 
    books = models.Book.objects.first().exists()  
    return HttpResponse("<p>查找成功!</p>")

values() 方法用于查询部分字段的数据。

返回的是 QuerySet 类型数据,类似于 list,里面不是模型类的对象,而是一个可迭代的字典序列,字典里的键是字段,值是数据。

注意:

  • 参数的字段名要加引号
  • 想要字段名和数据用 values
  • 实例

    from django.shortcuts import render,HttpResponse
    from app01 import models 
    def add_book(request):
        # 查询所有的id字段和price字段的数据 
        books = models.Book.objects.values("pk","price") 
        print(books[0]["price"],type(books)) # 得到的是第一条记录的price字段的数据
        return HttpResponse("<p>查找成功!</p>")

    values_list() 方法用于查询部分字段的数据。

    返回的是 QuerySet 类型数据,类似于 list,里面不是模型类的对象,而是一个个元组,元组里放的是查询字段对应的数据。

    注意:

    • 参数的字段名要加引号
    • 只想要数据用 values_list

    实例


    from django.shortcuts import render,HttpResponse
    from app01 import models 
    def add_book(request):
        # 查询所有的price字段和publish字段的数据 
        books = models.Book.objects.values_list("price","publish") 
        print(books)
        print(books[0][0],type(books)) # 得到的是第一条记录的price字段的数据
        return HttpResponse("<p>查找成功!</p>")

    distinct() 方法用于对数据进行去重。

    返回的是 QuerySet 类型数据。

    注意:

    • 对模型类的对象去重没有意义,因为每个对象都是一个不一样的存在。
    • distinct() 一般是联合 values 或者 values_list 使用。

    实例

    from django.shortcuts import render,HttpResponse
    from app01 import models 
    def add_book(request):
        # 查询一共有多少个出版社 
        books = models.Book.objects.values_list("publish").distinct() # 对模型类的对象去重没有意义,因为每个对象都是一个不一样的存在。 
        books = models.Book.objects.distinct()
        return HttpResponse("<p>查找成功!</p>")

    filter() 方法基于双下划线的模糊查询(exclude 同理)。

    注意:filter 中运算符号只能使用等于号 = ,不能使用大于号 > ,小于号 < ,等等其他符号。

    __in 用于读取区间,= 号后面为列表 。

    实例

    from django.shortcuts import render,HttpResponse
    from app01 import models 
    def add_book(request):
        # 查询价格为200或者300的数据 
        books = models.Book.objects.filter(price__in=[200,300])
        return HttpResponse("<p>查找成功!</p>")

    __gt 大于号 ,= 号后面为数字。

    # 查询价格大于200的数据 
    books = models.Book.objects.filter(price__gt=200)
    __gte 大于等于,= 号后面为数字。

    # 查询价格大于等于200的数据 
    books = models.Book.objects.filter(price__gte=200)

    __lt 小于,=号后面为数字。

    # 查询价格小于300的数据 
    books=models.Book.objects.filter(price__lt=300)

    __lte 小于等于,= 号后面为数字。

    # 查询价格小于等于300的数据 
    books=models.Book.objects.filter(price__lte=300)

    __range 在 ... 之间,左闭右闭区间,= 号后面为两个元素的列表。

    books=models.Book.objects.filter(price__range=[200,300])

    __contains 包含,= 号后面为字符串。

    books=models.Book.objects.filter(title__contains="菜")

    __icontains 不区分大小写的包含,= 号后面为字符串。

    books=models.Book.objects.filter(title__icontains="python") # 不区分大小写

    __startswith 以指定字符开头,= 号后面为字符串。

    books=models.Book.objects.filter(title__startswith="菜")

    __endswith 以指定字符结尾,= 号后面为字符串。

    books=models.Book.objects.filter(title__endswith="教程")

    __year 是 DateField 数据类型的年份,= 号后面为数字。

    books=models.Book.objects.filter(pub_date__year=2008) 

    __month 是DateField 数据类型的月份,= 号后面为数字。

    books=models.Book.objects.filter(pub_date__month=10) 

    __day 是DateField 数据类型的天数,= 号后面为数字。

    books=models.Book.objects.filter(pub_date__day=01)

    删除

    方式一:使用模型类的 对象.delete()。

    返回值:元组,第一个元素为受影响的行数。

    books=models.Book.objects.filter(pk=8).first().delete()

    方式二:使用 QuerySet 类型数据.delete()(推荐)

    返回值:元组,第一个元素为受影响的行数。

    books=models.Book.objects.filter(pk__in=[1,2]).delete()

    注意:

    • a. Django 删除数据时,会模仿 SQL约束 ON DELETE CASCADE 的行为,也就是删除一个对象时也会删除与它相关联的外键对象。
    • b. delete() 方法是 QuerySet 数据类型的方法,但并不适用于 Manager 本身。也就是想要删除所有数据,不能不写 all。
    books=models.Book.objects.delete()  # 报错
    books=models.Book.objects.all().delete()   # 删除成功

    修改

    方式一:

    模型类的对象.属性 = 更改的属性值
    模型类的对象.save()

    返回值:编辑的模型类的对象。

    books = models.Book.objects.filter(pk=7).first() 
    books.price = 400 
    books.save()

    方式二:QuerySet 类型数据.update(字段名=更改的数据)(推荐)

    返回值:整数,受影响的行数

    实例

    from django.shortcuts import render,HttpResponse
    from app01 import models 
    def add_book(request):
        books = models.Book.objects.filter(pk__in=[7,8]).update(price=888)
        return HttpResponse(books)

标签:objects,models,ORM,Django,Book,books,单表,import,app01
From: https://blog.csdn.net/2401_89581675/article/details/144459641

相关文章

  • Deformable DETR
    PDF:https://arxiv.org/pdf/2010.04159Code:https://github.com/fundamentalvision/Deformable-DETR一、大体内容前面介绍DETR时,说明了其还存在对小物体检测效果不佳和训练慢的问题,DeformableDETR引入了DCN(DeformableConvolutionalNetworks)并将其和DETR相结合,借助可变形卷积......
  • 在一个svg里进行大量线段的绘制,请问有没有什么可以提高性能的办法,类似 winform里的Sus
    在前端开发中,尤其是在处理SVG图形和大量线段绘制时,性能优化是非常重要的。虽然不像WinForms中的`SuspendLayout`和`ResumeLayout`那样直接控制布局更新的暂停与恢复,但在Web环境中也有多种方法可以提高SVG渲染性能。以下是几种常见的优化策略:###1.使用批量更新尽量减少DOM操作......
  • 基于django的python校园用车管理系统校车使用记录(源码+文档+运行视频+讲解视频)
     文章目录系列文章目录前言一、开发介绍二、详细视频演示三、项目部分实现截图四、系统测试五、代码参考源码获取目的摘要:基于Django的Python校园用车管理系统为学校的校车管理提供了便捷的工具。该系统借助Django框架的稳定性和Python语言的高效性,实现了校......
  • 基于django的python图书馆管理系统图书借阅归还续借逾期罚金缴纳(源码+文档+运行视频+
     文章目录系列文章目录前言一、开发介绍二、详细视频演示三、项目部分实现截图四、系统测试五、代码参考源码获取目的摘要:基于Django的Python图书馆管理系统为图书馆的管理和服务提供了全面的解决方案。该系统通过Django框架的高效性和Python语言的灵活性,实......
  • RepoDB:一个介于Dapper、EFCore之间.Net的ORM库
    推荐一个介轻量ORM和全功能ORM的开源项目。01项目简介RepoDB提供了基本操作所需的方法,同时也提供了一些高级功能,如第二层缓存、跟踪、仓储、属性处理器和批量/大量操作。支持的数据库,包括SqlServer、SQLite、MySql和PostgreSql等。02关键特性1、基础操作支持RepoDB提供了......
  • Forms表单中的full_clean方法和django中模型的save()方法之前手动调用的full_clean()方
    它们是两个独立的实现,分别存在于Django的Model和Form对象中,用于验证不同的数据类型和场景。1.两种full_clean()方法的区别1.1Model.full_clean()•定义位置:django.db.models.Model•调用时机:必须手动调用,Django默认不会在保存(save())时自动调用它。•作用:•......
  • NLP界大牛讲Transformer自然语言处理的经典书!,466页pdf及代码
    《Transformer自然语言处理实战》本书涵盖了Transformer在NLP领域的主要应用。内容介绍:首先介绍Transformer模型和HuggingFace生态系统。然后重点介绍情感分析任务以及TrainerAPI、Transformer的架构,并讲述了在多语言中识别文本内实体的任务,以及Transformer模型生成......
  • 如何在易优CMS中创建分页加载文件 formreply_block001.htm?
    在易优CMS中,为了实现分页加载功能,需要创建一个分页加载文件 formreply_block001.htm。以下是详细的步骤和说明:创建文件:在模板目录 pc/system 或 mobile/system 下创建一个名为 formreply_block001.htm 的文件。具体路径如下:PC端:模板目录/pc/system/formreply_block0......
  • 《Django 5 By Example》阅读笔记:p551-p560
    《Django5ByExample》学习第20天,p551-p560总结,总计10页。一、技术总结1.custommodelfield(1)示例courses/fields.pyfromdjango.core.exceptionsimportObjectDoesNotExistfromdjango.dbimportmodelsclassOrderField(models.PositiveIntegerField):d......
  • 超强 !顶会创新融合!基于 2D-SWinTransformer 的并行分类网络
    往期精彩内容:Python-凯斯西储大学(CWRU)轴承数据解读与分类处理基于FFT+CNN-BiGRU-Attention时域、频域特征注意力融合的轴承故障识别模型-CSDN博客基于FFT+CNN-Transformer时域、频域特征融合的轴承故障识别模型-CSDN博客Python轴承故障诊断(11)基于VMD+CNN-B......