Django的models.model如何使用

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)
      • [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

用于存储布尔值(TrueFalse)。

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 更加灵活强大。

相关推荐
Jackilina_Stone5 分钟前
【python】三帧差法实现运动目标检测
python·计算机视觉·od·运动目标检测
Icomi_9 分钟前
【PyTorch】3.张量类型转换
c语言·c++·人工智能·pytorch·python·深度学习·神经网络
寒冰碧海15 分钟前
使用ArcMap或ArcGIS Pro连接达梦数据库创建空间数据库
数据库
GISer Liu41 分钟前
深入理解Transformer中的解码器原理(Decoder)与掩码机制
开发语言·人工智能·python·深度学习·机器学习·llm·transformer
金融OG41 分钟前
6. 马科维茨资产组合模型+政策意图AI金融智能体(DeepSeek-V3)增强方案(理论+Python实战)
大数据·人工智能·python·算法·机器学习·数学建模·金融
金融OG44 分钟前
99.15 金融难点通俗解释:毛利率vs营业利润率vs净利率
大数据·数据库·python·机器学习·金融
大数据张老师1 小时前
【实践】Python实现气象数据分析与可视化
python·信息可视化·数据分析·可视化
抱抱宝1 小时前
Pyecharts之双轴图表的魅力
python·信息可视化·数据分析·pyecharts
TANGLONG2221 小时前
【C++】类与对象初级应用篇:打造自定义日期类与日期计算器(2w5k字长文附源码)
java·c语言·开发语言·c++·python·面试·跳槽
martian6651 小时前
第23篇:Python开发进阶:详解测试驱动开发(TDD)
开发语言·驱动开发·python·tdd