• 售前

  • 售后

热门帖子
入门百科

Postgresql 数据库 varchar()字符占用多少字节介绍

[复制链接]
冷艳林壳 显示全部楼层 发表于 2021-10-26 12:24:15 |阅读模式 打印 上一主题 下一主题
如下所示:
  1. create table tmp1
  2. (
  3. name varchar(3)
  4. );
  5. select pg_size_pretty(pg_relation_size('tmp1'));
  6. -- 0 bytes
  7. insert into tmp(name) values('欧阳子');
  8. -- 8192 bytes
复制代码
8192 bytes = 8KB = 1页(数据库的最小单位)
8页 = 1区 = 64KB(记不清磁头一次取1区还是1页数据了)
pg_relation_size()函数用于查询表占用空间.
当表创建的时候, 是不占空间的, 插入数据后, 数据库至少使用1KB去生存数据, 不敷会继承增长.(不包罗MateData)
起首postgresql中varchar()生存的是字符.
即可以插入3个中文, 也可以插入三个字母大概数字.
一般数据库都是UTF-8编码.
在UTF-8编码下, 一个中文 3个字节. 字母大概英文 1个字节.
别的
  1. 1KB = 1024B = 1024Bytes
  2. 1Bytes = 1B = 8bit
复制代码
增补:postgres数据库varchar类型的最大长度
在分析一个场景时,postgres中的一个字段存储很长的字符串时,是否可能存在题目。被问到varchar类型的最大长度,不是很清晰。
查了一下,记录一下。
      名字      形貌                  character varying(n), varchar(n)      变长,有长度限制              character(n), char(n)      定长,不敷补空缺              text      变长,无长度限制    简单来说,varchar的长度可变,而char的长度不可变,对于postgresql数据库来说varchar和char的区别仅仅在于前者是变长,而后者是定长,最大长度都是10485760(1GB)
varchar不指定长度,可以存储最大长度(1GB)的字符串,而char不指定长度,默认则为1,这点必要留意。
text类型:在postgresql数据库里边,text和varchar险些无性能差异,区别仅在于存储结构的不同。
对于char的使用,应该在确定字符串长度的环境下使用,否则应该选择varchar大概text。
其他人说的最大长度是10485760,我不是DBA,也没做过这个实行。但是有疑问,编码格式不为UTF-8时,是否还是10485760?
text类型是挺好用的,如果必要存储一个复杂且结构可能会厘革的数据,搞成json字符串存储到text里也是很好的。感觉成了MongoDB
以上为个人经验,盼望能给大家一个参考,也盼望大家多多支持草根技术分享。如有错误或未思量完全的地方,望不吝见教。

帖子地址: 

回复

使用道具 举报

分享
推广
火星云矿 | 预约S19Pro,享500抵1000!
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

草根技术分享(草根吧)是全球知名中文IT技术交流平台,创建于2021年,包含原创博客、精品问答、职业培训、技术社区、资源下载等产品服务,提供原创、优质、完整内容的专业IT技术开发社区。
  • 官方手机版

  • 微信公众号

  • 商务合作