1.简介
Django的模型(Model)是Django应用程序的核心部分,用于定义和管理应用中的数据结构。每个模型都对应一个数据库表,而Django的ORM(对象关系映射)则允许你使用Python代码来操作数据库,而不需要编写SQL语句。通过Django的模型,你可以定义数据字段、设置字段类型和添加验证规则。
示例代码:
from django.db import models
class Author(models.Model):
name = models.CharField(max_length=100)
age = models.IntegerField()
2. 关系
在Django中,每个模型类对应数据库中的一个表,每个模型字段对应表中的一列。Django会根据你定义的模型自动生成相应的数据库表结构,并提供CRUD(创建、读取、更新、删除)操作。
示例代码:
# 模型定义
class Book(models.Model):
title = models.CharField(max_length=200)
author = models.ForeignKey(Author, on_delete=models.CASCADE)
published_date = models.DateField()
# 对应的数据库表结构
# 表名:appname_book
# 列:id, title, author_id, published_date
3. 设置
Django支持使用多数据库,可以通过配置 DATABASES
设置多个数据库,并在模型或查询中指定使用哪个数据库。
示例代码:
# settings.py
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.sqlite3',
'NAME': BASE_DIR / "db.sqlite3",
},
'secondary': {
'ENGINE': 'django.db.backends.postgresql',
'NAME': 'myotherdb',
'USER': 'myuser',
'PASSWORD': 'mypassword',
'HOST': 'localhost',
'PORT': '5432',
}
}
# 使用多数据库
from django.db import models
class Author(models.Model):
name = models.CharField(max_length=100)
class Book(models.Model):
title = models.CharField(max_length=200)
author = models.ForeignKey(Author, on_delete=models.CASCADE)
# 在查询中指定数据库
Author.objects.using('secondary').all()
Book.objects.using('default').create(title="Django for Beginners", author=author)
4. 迁移
Django通过迁移(migration)机制来跟踪和应用模型变化。迁移文件记录了模型的结构变化,可以通过 makemigrations
和 migrate
命令生成和应用迁移。
示例代码:
# 生成迁移文件
python manage.py makemigrations
# 应用迁移文件
python manage.py migrate
示例代码:
# 新增一个字段到Author模型
class Author(models.Model):
name = models.CharField(max_length=100)
age = models.IntegerField()
email = models.EmailField() # 新增字段
# 生成迁移文件
# 0002_auto__add_field_author_email.py
# 应用迁移
python manage.py migrate