Django中的ORM介绍

Django 的 ORM(Object-Relational Mapping,对象关系映射)是 Django 框架提供的数据库抽象层,允许开发者使用 Python 代码操作数据库,而无需直接编写 SQL 语句。它提供了一种高效、直观的方式来管理数据库模型和查询数据。

Django ORM 核心概念

1. 模型(Model)

Django ORM 使用 Python 类来定义数据库表,每个类对应数据库中的一张表,类的属性对应表的字段。

示例:

复制代码
from django.db import models

class Employee(models.Model):
    name = models.CharField(max_length=100)  # 字符串字段
    age = models.IntegerField()  # 整数字段
    department = models.ForeignKey('Department', on_delete=models.CASCADE)  # 外键

    def __str__(self):
        return self.name
  • CharFieldIntegerField 等字段对应数据库中的不同类型列。
  • ForeignKey 用于建立表之间的关系。

2. 迁移(Migrations)

创建或修改模型后,需要执行迁移,以便同步数据库结构:

复制代码
python manage.py makemigrations
python manage.py migrate

3. 查询数据

Django ORM 允许使用 QuerySet 查询数据,例如:

复制代码
# 获取所有员工
employees = Employee.objects.all()

# 筛选年龄大于 30 的员工
employees_over_30 = Employee.objects.filter(age__gt=30)

# 获取单个对象
employee = Employee.objects.get(id=1)

# 排序
employees = Employee.objects.order_by('-age')

# 计数
count = Employee.objects.count()

4. 插入数据

复制代码
new_employee = Employee(name="张三", age=28)
new_employee.save()

或者使用 create 方法:

复制代码
Employee.objects.create(name="李四", age=32)

5. 更新数据

复制代码
employee = Employee.objects.get(id=1)
employee.age = 35
employee.save()

6. 删除数据

复制代码
employee = Employee.objects.get(id=1)
employee.delete()

Django ORM 的优点

  • 避免手写 SQL,让开发更加 Pythonic。
  • 数据库无关性,支持 SQLite、MySQL、PostgreSQL 等多种数据库。
  • 安全性,自动防止 SQL 注入。

如果你的项目需要使用数据库,Django ORM 是一个强大的工具,可以极大提高开发效率。

相关推荐
真正的醒悟15 分钟前
什么是安全设备组网
服务器·数据库·php
小哈里28 分钟前
【软考架构】2025H2系统架构设计师考试复习.jpg(软件架构、软件工程、数据库、Web开发、高项)
数据库·架构·系统架构·软件工程·后端开发
B站_计算机毕业设计之家37 分钟前
深度学习:Yolo水果检测识别系统 深度学习算法 pyqt界面 训练集测试集 深度学习 数据库 大数据 (建议收藏)✅
数据库·人工智能·python·深度学习·算法·yolo·pyqt
wei_shuo3 小时前
全场景自动化 Replay 技术:金仓 KReplay 如何攻克数据库迁移 “难验证“ 难题
数据库·自动化·king base
葡萄城技术团队3 小时前
打破误解!MongoDB 事务隔离级别深度实测:快照隔离竟能防住 8 种异常?
数据库
Gold Steps.3 小时前
数据库正常运行但是端口变成了0?
数据库·mysql
杂亿稿3 小时前
增删改查操作
数据库
Code_Geo3 小时前
在postgres数据库中Postgres FDW 全面详解
数据库·fdw
QT 小鲜肉3 小时前
【个人成长笔记】将Try Ubuntu里面配置好的文件系统克隆在U盘上(创建一个带有持久化功能的Ubuntu Live USB系统)
linux·开发语言·数据库·笔记·ubuntu
LWy6104263 小时前
数据库库、表的创建及处理
数据库