Django模型字段类型与MySQL数据库类型的对应关系如下:
|-----------------------|------------------------------|
| Django 模型字段类型 | MySQL 数据库类型 |
| AutoField | BIGINT UNSIGNED |
| CharField | VARCHAR |
| IntegerField | INT |
| DecimalField | DECIMAL |
| DateField | DATE |
| DateTimeField | DATETIME |
| FileField, ImageField | VARCHAR (用于文件路径) |
| BooleanField | BOOL (如果MySQL版本支持) 或 TINYINT |
| TextField | TEXT |
注意:
1、对于BooleanField,MySQL的BOOL类型在较旧的MySQL版本中可能不支持,可以使用TINYINT代替。
2、文件路径通常存储在VARCHAR字段中。
3、日期时间使用DATE、DATETIME或TIMESTAMP字段。
4、十进制数字使用DECIMAL字段。
示例代码:
python
from django.db import models
class ExampleModel(models.Model):
id = models.AutoField(primary_key=True)
name = models.CharField(max_length=100)
age = models.IntegerField()
salary = models.DecimalField(max_digits=10, decimal_places=2)
birth_date = models.DateField()
last_login = models.DateTimeField()
is_active = models.BooleanField(default=True)
description = models.TextField()
在这个示例中,每个字段都会被转换成MySQL数据库对应的类型。BooleanField可能会使用TINYINT代替BOOL,这取决于MySQL的版本。