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

news/2024/6/18 6:17:18 标签: 数据库, django

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

在这里插入图片描述

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

在这里插入图片描述
在这里插入图片描述

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

在这里插入图片描述

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

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-数据库迁移命令生成

相关命令如下:

CD E:\Python_project\P_001\myshop-test\myshop\
E:
manage.py makemigrations

在这里插入图片描述

06-执行数据库迁移命令

manage.py migrate

在这里插入图片描述

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

07-1-测试中文汉字

在这里插入图片描述

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时是可以写入成功的。

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

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

此时运行报错,原因是字符串超过规定超过长度了:
在这里插入图片描述

07-1-测试英文字符

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

user = User(username='abcd', email='b001@example.com')
user.save()

在这里插入图片描述
可见能成功写入

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

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


http://www.niftyadmin.cn/n/5316844.html

相关文章

L1-018 大笨钟(Java)

微博上有个自称“大笨钟V”的家伙,每天敲钟催促码农们爱惜身体早点睡觉。不过由于笨钟自己作息也不是很规律,所以敲钟并不定时。一般敲钟的点数是根据敲钟时间而定的,如果正好在某个整点敲,那么“当”数就等于那个整点数&#xff…

ubuntu22安装NetworkManager

步骤1: 检查NetworkManager服务是否已安装 在终端中运行以下命令: systemctl status NetworkManager 如果你看到"NetworkManager.service"在list of loaded units中,那么说明服务已经安装并在运行中 步骤2: 安装NetworkManager服务 如果在步骤1中发现NetworkMan…

王道计算机考研 数据结构C语言复现-第七章-表达式(波兰式)

这篇文章收录了王道考研课程中涉及的数据结构的所有代码。此外,本博客可能会添加一些额外的代码(不仅限于王道考研),因为408考试中会频繁考察一些冷门的知识点,所以这篇博客会涵盖所有相关的代码。这也是我数据结构的第…

Qt 窗口阴影边框

环境:Qt 5.15 VS2019 方法一:QGraphicsDropShadowEffect 实现方法参考链接:https://blog.csdn.net/goforwardtostep/article/details/99549750 使用此方法添加窗口阴影,会出现警告信息: 且窗口最大化与还原切换时会…

7.云原生之jenkins集成SonarQube

1. 私有云实战之基础环境搭建 2. 云原生实战之kubesphere搭建 3.云原生之kubesphere运维 4. 云原生之kubesphere基础服务搭建 5.云原生安全之kubesphere应用网关配置域名TLS证书 6.云原生之DevOps和CICD 7.云原生之jenkins集成SonarQube 8.云原生存储之Ceph集群 文章目录 搭建 …

C++11_lambda表达式

文章目录 一、lambda表达式1.lambda的组成2.[capture-list] 的其他使用方法2.1混合捕捉 二、lambda表达式的使用场景1.替代仿函数 总结 一、lambda表达式 lambda表达式是C11新引入的功能,它的用法与我们之前学过的C语法有些不同。 1.lambda的组成 [capture-list] …

【Leetcode】268.丢失的数字

一、题目 1、题目描述 给定一个包含 [0, n] 中 n 个数的数组 nums ,找出 [0, n] 这个范围内没有出现在数组中的那个数。 示例1: 输入:nums = [3,0,1] 输出:2 解释:n = 3,因为有 3 个数字,所以所有的数字都在范围 [0,3] 内。2 是丢失的数字,因为它没有出现在 nums 中…

Java平衡树--红黑树,如何平衡化以及操作实现

Java 学习面试指南:https://javaxiaobear.cn 我们前面介绍了2-3树,可以看到2-3树能保证在插入元素之后,树依然保持平衡状态,它的最坏情况下所有子结点都是2-结点,树的高度为lgN,相比于我们普通的二叉查找树&#xff0…