Django的对象关系映射器(ORM)是其核心功能之一,允许开发者使用Python代码来定义、操作和查询数据库。这篇文章将带你深入了解Django ORM的强大之处,从基本概念到高级查询技巧,提供丰富的示例帮助你掌握使用Django ORM进行有效和高效的数据库操作。
1. Django ORM基础
Django ORM的目的是提供一种简单的方法用来:
- 将复杂的SQL查询转换为Python代码
- 保护项目免受SQL注入攻击
- 提供数据库后端的独立性
定义模型
在Django中,每个数据库表由一个Python类表示,这个类继承自django.db.models.Model
。
from django.db import models
class Author(models.Model):
name = models.CharField(max_length=100)
age = models.IntegerField()
def __str__(self):
return self.name
进行数据库迁移
定义模型后,使用makemigrations
和migrate
命令创建或更新数据库结构。
python manage.py makemigrations
python manage.py migrate
2. 创建记录
使用模型的构造函数创建新记录。
new_author = Author(name='J.K. Rowling', age=54)
new_author.save()
使用create
方法
可以使用模型管理器的create
方法更快捷地创建记录。
Author