Django的models.model如何使用
-
-
- [1. 什么是 Django 模型?](#1. 什么是 Django 模型?)
- [2. 创建一个 Django 模型](#2. 创建一个 Django 模型)
-
- [2.1 定义模型](#2.1 定义模型)
- [2.2 字段类型](#2.2 字段类型)
- [2.3 字符串表示(`str`)](#2.3 字符串表示(
__str__
))
- [3. 创建数据库表](#3. 创建数据库表)
-
- [3.1 生成迁移文件](#3.1 生成迁移文件)
- [3.2 应用迁移](#3.2 应用迁移)
- [4. 使用模型进行数据操作](#4. 使用模型进行数据操作)
-
- [4.1 创建对象并保存](#4.1 创建对象并保存)
- [4.2 查询数据](#4.2 查询数据)
- [4.3 更新对象](#4.3 更新对象)
- [4.4 删除对象](#4.4 删除对象)
- [5. 常见字段类型及参数](#5. 常见字段类型及参数)
-
- [5.1 `CharField`](#5.1
CharField
) - [5.2 `IntegerField`](#5.2
IntegerField
) - [5.3 `DateTimeField`](#5.3
DateTimeField
) - [5.4 `ForeignKey`](#5.4
ForeignKey
) - [5.5 `ManyToManyField`](#5.5
ManyToManyField
) - [5.6 `BooleanField`](#5.6
BooleanField
)
- [5.1 `CharField`](#5.1
- [6. 使用模型进行迁移和管理](#6. 使用模型进行迁移和管理)
-
- [6.1 管理后台](#6.1 管理后台)
- [6.2 自定义模型管理](#6.2 自定义模型管理)
- [7. 总结](#7. 总结)
-
在 Django 中,models
是处理数据库的核心工具,允许我们通过定义 Python 类来描述数据结构,并自动生成数据库表。本文将介绍如何使用 Django 的模型来设计和操作数据库表。
1. 什么是 Django 模型?
Django 模型是 Python 类,继承自 django.db.models.Model
类,每个模型类都对应数据库中的一张表。模型类的属性定义了表的字段(列),并可以通过各种方法对表中的数据进行操作(如添加、删除、修改和查询)。
2. 创建一个 Django 模型
假设我们正在开发一个简单的应用程序,管理坦克的基本信息。我们可以定义一个 Tank
模型来存储坦克的名字、生命值和速度等属性。
2.1 定义模型
在 Django 中,你通常会在应用的 models.py
文件中定义模型类。每个字段都是一个 Field
类型,Django 会自动为每个字段创建数据库表的相应列。
python
# models.py
from django.db import models
class Tank(models.Model):
name = models.CharField(max_length=100) # 坦克的名字
health = models.IntegerField() # 坦克的生命值
speed = models.FloatField() # 坦克的速度
created_at = models.DateTimeField(auto_now_add=True) # 创建时间
def __str__(self):
return self.name
2.2 字段类型
在模型中,我们定义了不同类型的字段:
CharField(max_length=100)
:用于存储字符串数据,max_length
参数指定字段的最大长度。IntegerField()
:用于存储整数值。FloatField()
:用于存储浮动小数点数。DateTimeField(auto_now_add=True)
:用于存储日期和时间,auto_now_add=True
表示每次创建对象时自动设置当前时间。
2.3 字符串表示(__str__
)
我们重写了 __str__
方法,确保在管理界面中或通过查询时,返回坦克的名称。
3. 创建数据库表
定义好模型后,Django 会根据模型生成数据库表。接下来,我们需要通过迁移操作将模型同步到数据库。
3.1 生成迁移文件
使用以下命令生成迁移文件,Django 会根据模型的变化自动生成数据库操作脚本:
bash
python manage.py makemigrations
3.2 应用迁移
执行迁移操作,将模型同步到数据库:
bash
python manage.py migrate
4. 使用模型进行数据操作
Django 提供了一个强大的 ORM(对象关系映射)系统,通过模型类,你可以方便地进行增、删、改、查等操作。
4.1 创建对象并保存
你可以使用模型类创建新的数据记录,并保存到数据库:
python
tank = Tank(name="T-34", health=100, speed=50.0)
tank.save() # 将对象保存到数据库
4.2 查询数据
你可以通过模型的 objects
属性执行数据库查询。Django 提供了多种查询方法,常见的包括:
all()
:获取所有记录。get()
:根据条件获取单个记录。filter()
:根据条件过滤记录。exclude()
:排除某些记录。
python
# 获取所有坦克
tanks = Tank.objects.all()
# 获取 id 为 1 的坦克
tank = Tank.objects.get(id=1)
# 获取速度大于 40 的坦克
fast_tanks = Tank.objects.filter(speed__gt=40)
# 排除掉生命值低于 50 的坦克
healthy_tanks = Tank.objects.exclude(health__lt=50)
4.3 更新对象
查询到的对象是可修改的,你可以直接修改其属性并保存:
python
tank = Tank.objects.get(id=1)
tank.speed = 60.0 # 修改速度
tank.save() # 保存修改
4.4 删除对象
你可以删除数据库中的记录:
python
tank = Tank.objects.get(id=1)
tank.delete() # 删除坦克对象
5. 常见字段类型及参数
Django 提供了丰富的字段类型,用于处理各种不同类型的数据。常见的字段类型及参数如下:
5.1 CharField
用于存储字符串,通常用于存储名称、标题等短文本。
python
name = models.CharField(max_length=100)
max_length
:字段的最大长度(必需)。
5.2 IntegerField
用于存储整数。
python
health = models.IntegerField()
null
:如果为True
,该字段可以为空。blank
:如果为True
,该字段可以在表单中为空。
5.3 DateTimeField
用于存储日期和时间。
python
created_at = models.DateTimeField(auto_now_add=True)
auto_now
:每次保存模型时自动设置为当前时间。auto_now_add
:只在对象创建时自动设置为当前时间。
5.4 ForeignKey
表示一对多关系。通常用于关联其他模型。
python
author = models.ForeignKey('Author', on_delete=models.CASCADE)
on_delete
:定义删除关联对象时的行为。常见的选项有:models.CASCADE
:级联删除,删除关联对象时也删除当前对象。models.SET_NULL
:将外键字段设置为NULL
。models.PROTECT
:阻止删除关联对象。models.SET_DEFAULT
:将外键字段设置为默认值。
5.5 ManyToManyField
表示多对多关系。适用于多个模型实例与多个其他模型实例之间的关系。
python
authors = models.ManyToManyField('Author')
related_name
:定义反向关系的名称。
5.6 BooleanField
用于存储布尔值(True
或 False
)。
python
is_active = models.BooleanField(default=True)
default
:设置字段的默认值。
6. 使用模型进行迁移和管理
6.1 管理后台
Django 提供了内置的管理后台,方便你管理模型数据。你只需要在 admin.py
中注册你的模型。
python
# admin.py
from django.contrib import admin
from .models import Tank
admin.site.register(Tank)
6.2 自定义模型管理
你还可以自定义模型的管理方法,来简化常见的查询或操作。例如,你可以通过自定义管理类来添加一些常用的查询方法:
python
class TankManager(models.Manager):
def fast_tanks(self):
return self.filter(speed__gt=50)
class Tank(models.Model):
name = models.CharField(max_length=100)
speed = models.FloatField()
objects = TankManager() # 使用自定义的管理类
这样,你就可以通过 Tank.objects.fast_tanks()
来获取速度大于 50 的所有坦克。
7. 总结
Django 的模型是与数据库交互的桥梁。通过定义模型类,你可以轻松地进行增、删、改、查等操作,且无需直接编写 SQL 语句。通过合理使用模型字段、外键、多对多关系等功能,你可以构建复杂的数据库结构,并高效地管理数据。
在实际应用中,你还可以通过自定义方法、查询集、管理器等扩展模型的功能,使得 Django 的 ORM 更加灵活强大。