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个字节的存储空间。

相关推荐
被摘下的星星1 天前
MySQL count()函数的用法
数据库·mysql
末央&1 天前
【天机论坛】项目环境搭建和数据库设计
java·数据库
徒 花1 天前
数据库知识复习07
数据库·作业
素玥1 天前
实训5 python连接mysql数据库
数据库·python·mysql
jnrjian1 天前
text index 查看index column index定义 index 刷新频率 index视图
数据库·oracle
瀚高PG实验室1 天前
审计策略修改
网络·数据库·瀚高数据库
言慢行善1 天前
sqlserver模糊查询问题
java·数据库·sqlserver
韶博雅1 天前
emcc24ai
开发语言·数据库·python
有想法的py工程师1 天前
PostgreSQL 分区表排序优化:Append Sort 优化为 Merge Append
大数据·数据库·postgresql
迷枫7121 天前
达梦数据库的体系架构
数据库·oracle·架构