Django的数据库模型的CharField字段的max_length参数与中文字符数的关系探索(参数max_length的单位是字符个数还是字节数?)

01-清理干净之前的数据库迁移信息

02-根据setting.py中的信息删除掉之前建立的数据库


03-删除之后重新创建数据库

04-models.py中创建数据库模型

python 复制代码
from django.db import models


class User(models.Model):
    username = models.CharField(max_length=4)
    email = models.EmailField(unique=True)

    # 其他字段...

    def __str__(self):
        return self.username

在上面的数据库模型代码中我对字段username限制为4个长度,我们进行如下测试

①4个中文汉字能不能正常写入;

②5个中文汉字能不能正常写入;

③4个英文字符能不能正常写入;

④5个英文字符能不能正常写入;

05-数据库迁移命令生成

相关命令如下:

bash 复制代码
CD E:\Python_project\P_001\myshop-test\myshop\
E:
manage.py makemigrations

06-执行数据库迁移命令

bash 复制代码
manage.py migrate

07-写入数据到数据库进行测试

07-1-测试中文汉字

python 复制代码
import os
import django

# 设置Dango运行时需要的环境变量DJANGO_SETTINGS_MODULE
os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'myshop.settings')

# 加载Django的设置
django.setup()

# 导入模型,注意必须在加载完Django的设置后下面的这句导入模型语句才能被正确执行
from app1.models import User

# # 清空User数据表
# User.objects.all().delete()
# 
# print('Successfully written data to the database.')


# 创建一个用户
user = User(username='欧阳娃娃', email='john@example.com')
user.save()

运行上面的代码后,查看数据表是否写入成功:

可见是写入成功了,也就是说四个中文汉字在max_length=4时是可以写入成功的。

运行下面的代码测试五个中文汉字的情况:

python 复制代码
user = User(username='你是我的儿', email='a002@example.com')
user.save()

此时运行报错,原因是字符串超过规定超过长度了:

07-1-测试英文字符

运行下面的代码测试四个英文字符的情况:

python 复制代码
user = User(username='abcd', email='b001@example.com')
user.save()

可见能成功写入

运行下面的代码测试五个英文字符的情况:

python 复制代码
user = User(username='abcde', email='b002@example.com')
user.save()

此时报错:

08-结论:

Django数据库模型中的参数max_length的单位是字符个数,而不是字节数。

如果你的max_length为100,而且你的字符编码是UTF-8,那么这个字段可以存储包含100个字符的字符串,不管这些字符是英文、汉字还是其他字符。UTF-8 编码下,汉字通常占用3个字节,英文占用1个字节。因此,max_length=100 的情况下,如果是100个英文字符,就占用100个字节的存储空间,而如果是100个中文字符,就占用300个字节的存储空间。

相关推荐
BryceBorder13 小时前
SCAU--数据库
数据库·oracle·dba
有味道的男人13 小时前
京东关键词API接口获取
数据库
罗光记13 小时前
《人工智能安全治理研究报告(2025年)发布
数据库·其他·百度·新浪微博
202321336054 刘13 小时前
Linux常用命令分类整理
linux·运维·数据库
Q741_14713 小时前
海致星图招聘 数据库内核研发实习生 一轮笔试 总结复盘(2) 作答语言:C/C++ 哈夫曼编码 LRU
c语言·数据库·c++·算法·笔试·哈夫曼编码·哈夫曼树
齐 飞13 小时前
快速删除mysql表中所有数据-TRUNCATE TABLE
数据库·mysql
想摆烂的不会研究的研究生13 小时前
每日八股——Redis(2)
数据库·redis·缓存
optimistic_chen13 小时前
【Redis系列】主从复制
linux·数据库·redis·缓存·中间件·命令行·主从复制
一个天蝎座 白勺 程序猿14 小时前
KingbaseES 处理 PL/SQL 运行时错误全解析:从异常捕获到异常处理的实践指南
数据库·sql·oracle·kingbasees
leo_23214 小时前
表&表结构--SMP(软件制作平台)语言基础知识之三十三
数据库·开发工具·表结构·smp(软件制作平台)·应用系统