• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    Postgresql 数据库 varchar()字符占用多少字节介绍

    如下所示:

    create table tmp1
    (
    name varchar(3)
    );
    
    select pg_size_pretty(pg_relation_size('tmp1'));
    -- 0 bytes
    
    insert into tmp(name) values('欧阳子');
    -- 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个字节.

    另外

    1KB = 1024B = 1024Bytes

    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

    以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。如有错误或未考虑完全的地方,望不吝赐教。

    您可能感兴趣的文章:
    • postgresql 查询字符串中是否包含某字符的操作
    • PostgreSQL 使用raise函数打印字符串
    • PostgreSQL 字符串拆分与合并案例
    • PostgreSQL去掉表中所有不可见字符的操作
    • 解决postgresql 数字转换成字符串前面会多出一个空格的问题
    • postgreSQL 数字与字符串类型转换操作
    • Postgresql 数据库转义字符操作
    上一篇:解决postgresql 数字转换成字符串前面会多出一个空格的问题
    下一篇:PostgreSQL去掉表中所有不可见字符的操作
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

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