使用 Django ORM 进行数据库操作

文章目录

    • 创建Django项目和应用
    • 定义模型
    • 查询数据
    • 更新和删除数据
    • 总结与进阶
      • 聚合和注解
      • 跨模型查询
      • 原始SQL查询

Django是一个流行的Web应用程序框架,它提供了一个强大且易于使用的对象关系映射(ORM)工具,用于与数据库进行交互。在本文中,我们将介绍如何使用Django ORM进行数据库操作,包括创建模型、查询数据、更新和删除等。
在这里插入图片描述

创建Django项目和应用

首先,确保你已经安装了Django。如果没有安装,可以使用以下命令进行安装:

pip install django

接下来,创建一个新的Django项目和一个应用:

django-admin startproject myproject
cd myproject
python manage.py startapp myapp

定义模型

在Django中,模型是与数据库表对应的Python类。在myapp/models.py文件中定义模型:

from django.db import modelsclass Author(models.Model):name = models.CharField(max_length=100)email = models.EmailField()def __str__(self):return self.nameclass Book(models.Model):title = models.CharField(max_length=200)author = models.ForeignKey(Author, on_delete=models.CASCADE)publish_date = models.DateField()def __str__(self):return self.title

然后,在myproject/settings.py文件中将myapp应用添加到INSTALLED_APPS列表中:

INSTALLED_APPS = [# ...'myapp',# ...
]

运行以下命令创建数据库表:

python manage.py makemigrations
python manage.py migrate

查询数据

使用Django ORM可以轻松地执行各种类型的数据库查询。例如,以下是一些常见的查询示例:

# 获取所有的作者
authors = Author.objects.all()# 根据条件过滤书籍
recent_books = Book.objects.filter(publish_date__gte='2022-01-01')# 获取单个对象
book = Book.objects.get(title='Python入门指南')

更新和删除数据

更新数据也很简单,只需使用save()方法保存修改后的对象:

book = Book.objects.get(title='Python入门指南')
book.title = 'Python进阶指南'
book.save()

要删除数据,可以使用delete()方法:

book = Book.objects.get(title='Python进阶指南')
book.delete()

总结与进阶

除了基本的数据库操作外,Django ORM还提供了许多其他高级功能,可以帮助开发人员更好地管理数据。一些拓展的内容包括:

聚合和注解

Django ORM允许使用聚合函数(如Sum、Count等)来执行复杂的数据分析操作,同时也支持使用注解(annotate)对查询结果进行标注,为结果集添加额外的信息。

from django.db.models import Count
# 计算每位作者出版的书籍数量
authors_with_book_count = Author.objects.annotate(book_count=Count('book'))

跨模型查询

通过Django ORM可以方便地进行跨模型的查询,利用ForeignKey、ManyToManyField等字段建立模型之间的关联,并且可以通过这些关联进行复杂的数据检索操作。

# 获取某个作者的所有书籍
author = Author.objects.get(name='张三')
books = author.book_set.all()

原始SQL查询

虽然Django ORM提供了强大的查询API,但有时候仍然需要执行原始的SQL查询。Django ORM允许开发人员执行原始的SQL查询,并将结果映射到模型中。

from django.db import connection
# 执行原始的SQL查询
with connection.cursor() as cursor:cursor.execute("SELECT * FROM myapp_author")row = cursor.fetchone()

通过深入学习和掌握这些进阶功能,开发人员可以更好地利用Django ORM来处理各种复杂的数据库操作,从而更高效地构建稳健的Web应用程序。

希望本文能够帮助你更全面地理解和应用Django ORM,进一步提升开发技能和应用水平!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/16845.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Flutter 中的 DefaultTabController 小部件:全面指南

Flutter 中的 DefaultTabController 小部件:全面指南 在Flutter中,DefaultTabController是一个用于管理Tab控制器的widget,它允许你控制Tab视图的初始索引和动态更新。这个组件在实现具有可滚动标签页的界面时非常有用,例如在设置…

优路教育:为行业发展培养高素质技术技能人才,推进新质生产力发展

职业教育是面向行业、企业培养技术技能人才的特色类型教育。随着技术和市场的加速演进,新技术、新业态出现,相应地迭现出众多新兴职业,也暴露了各新兴领域庞大的人才缺口。其中,高技能人才的高需求,也为职业教育育人标…

Java中的代理模式:灵活地控制对象访问和行为

代理模式是一种结构型设计模式,它允许一个对象(代理对象)代替另一个对象(被代理对象)来控制对其的访问。代理对象通常在不改变原始对象的情况下,提供额外的功能或控制访问的方式。在Java编程中,…

大数据开发面试题【数仓篇】

197、数据仓库和传统数据库区别 由于历史数据使用频率过低,导致数据堆积,查询性能下降;用于查询分析,涉及大量的历史数据,数据仓库中的数据一般来日志文件和事务 数据库是跟业务挂钩的,数据库不可能装下一…

教育新篇章:AI工具Sora引领学习新趋势

Sora——这个让人在24年初引爆AI圈的新产品,它究竟会如何改变我们的教育领域呢? 从gpt到Sora,从对话型的ai到游戏和短剧制作的新风口,我们从23年到24年一个接一个地被震惊! Sora能够根据文本提示生成高质量的视频内容…

当 GIS 遇上 AI 大模型

今年整个 IT 界、甚至科技界最火爆的技术就是 AI 大模型了,没有之一。 以 OpenAI 的 GPT 为代表、国内外一众大模型跟进,形成了百模齐奔的态势。围绕着大模型,各项周边的应用也在快速发展。在 2023 年年底的云栖大会上,论坛标题带…

LVM部署手册

目录 前言 一、LVM的基本概念 二、LVM的特点 三、LVM的应用场景 四、总结 资源列表 一、基础环境 关闭防火墙 关闭内核安全机制 设置主机名 二、磁盘分区 使用fdisk命令将磁盘划分为三个主分区 将这三个分区ID标记好修改为”8e“ 三、创建物理卷 创建物理卷 查…

Vue3(TypeScript)-CSSProperties代码示例及用法详解

Vue3-CSSProperties代码示例及用法 在Vue3中封装一个可复用的公共CSSProperties // 目录 /xxx/src/hooks/use-scroll-updown-bottom-content/index.ts 全局定义hooks import { computed } from vue import type { CSSProperties } from vuetype UpDownOperationType up | down…

一个基于预训练的DenseNet121模型的人脸年龄分类系统

这篇文章采用预训练的DenseNet121模型并使用自定义的数据集类和自定义的类似正态分布的标签平滑策略来训练了一个人脸年龄分类模型,最后基于这个模型用tk实现了一个娱乐向的小系统。 数据集展示: 两个文件夹,分别是训练集和测试集&#xff0…

Bootstrap 3.x 版本基础引入指南

Bootstrap 是一款广受欢迎的前端框架,它简化了网页设计与开发流程,帮助开发者快速创建响应式布局和美观的网页界面。本文将向您介绍如何在项目中引入 Bootstrap 3.x 版本的基本步骤,包括 CSS 和 JavaScript 文件的引用,以及必要的…

java根据不同类型跳转相应的实现类

1 不同实现类字典 AllArgsConstructor Getter public enum SendMessageEnum {HUAWEI("AndHWPush"),JIGUANG("AndJPush"),MEIZU("AndMZPush"),OPPO("AndOppoPush"),XIAOMI("AndXMPush"),XINGE("AndXinGePush"),;p…

Java跨Docker容器备份数据库数据

Java跨Docker容器备份数据库数据 前置背景思路整理编写备份脚本容器启动检验效果Java容器MySQL容器 Java代码执行备份 我的个人博客:Lichg,欢迎大家访问。 前置背景 在我们的开发部署场景中,通常多数使用Docker进行部署。当你的数据库和项目…

【吊打面试官系列】Java高并发篇 - 什么是乐观锁和悲观锁?

大家好,我是锋哥。今天分享关于 【什么是乐观锁和悲观锁?】面试题,希望对大家有帮助; 什么是乐观锁和悲观锁? 1、乐观锁: 就像它的名字一样,对于并发间操作产生的线程安全问题持乐观状态, 乐观锁认为竞争…

ICML 2024 多视角融合驱动的通用具身操作算法SAM-E,为机器人学习复杂操作给出了可行解决方案

当我们拿起一个机械手表时,从正面会看到表盘和指针,从侧面会看到表冠和表链,打开手表背面会看到复杂的齿轮和机芯。每个视角都提供了不同的信息,将这些信息综合起来才能理解操作对象的整体三维。 想让机器人在现实生活中学会执行…

【2024上半年软考】软件设计师答案

软件设计师 群策群力 仅供参考 ①数据库权限应该选revoke ②工作在数据链路层的设备是交换机 ③结构化思维:自上而下分解 ④链表需要遍历的是删除最后一个元素 ⑤磁盘是辅存 ⑥瀑布模型不够灵活 ⑦软件测试路径覆盖程度最高 ⑧29个数字最多查找5次的是有序数组进行二…

nuxt2移动端适配,处理移动端引入的组件库大小不正常显示

版本 "postcss-pxtorem": "^5.1.1" "nuxt": "^2.14.7"安装 npm i -D postcss-pxtorem5.1.1postcss.config.js 排除组件库适配,解决组件库大小在页面不正常显示 const pxToRem require(postcss-pxtorem) module.exports …

AI小天才:让你轻松掌握机器学习之K近邻

课程链接:AI小天才:让你轻松掌握机器学习 K近邻(K-Nearest Neighbors,简称KNN)算法是一种常用的监督学习算法,用于分类和回归任务。KNN算法的基本原理是通过找出与新样本最近的K个训练样本,并根…

【stm32】江科协听课笔记

[3-1] GPIO输出_哔哩哔哩_bilibili 5.GPIO输出 这里,寄存器就是一段特殊的存储器,内核可以通过APB2总线队寄存器进行读写,这样就可以完成输出/读取电平的功能。寄存器的每一位对应一个引脚,stm32是32位的,这里的寄存器…

【工具】珍藏免费宝藏工具,不好用你来捶我

前言 🍊缘由 藏在我硬盘里的好东西,必须跟小伙伴们分享 东西很好,必须分享。良辰吉日,跟大家分享几款神仙级小工具,实际亲测,不好来锤。 正文 一.影刀 影刀可以使任何操作系统、桌面软件、Web程序的自动…

怎么搭建微信留言板功能

在信息爆炸的时代,微信已经成为了我们日常生活中不可或缺的一部分。它不仅仅是一个简单的聊天工具,更是一个充满无限可能的营销平台。今天,我要向大家介绍的是如何在你的微信平台上搭建一个独具特色的留言板功能,让用户能够自由发…