我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Postgresql数据库character varying和character的区别说明

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Postgresql数据库character varying和character的区别说明

Postgresql character varying和character的区别

SQL 标准

SQL 定义了两种基本的字符类型:character varying(n) 和 character(n) ,这里的 n 是一个正整数。两种类型都可以存储最多 n 个字符的字符串。

试图存储更长的字符串到这些类型的字段里会产生一个错误,除非超出长度的字符都是空白,这种情况下该字符串将被截断为最大长度。

这个看上去有点怪异的例外是 SQL 标准要求的。如果要存储的字符串比声明的长度短,类型为 character 的数值将会用空白填满;而类型为 character varying 的数值将只是存储短些的字符串。

如果我们明确地把一个数值转换成 character varying(n) 或 character(n) ,那么超长的数值将被截断成 n 个字符,且不会抛出错误。这也是 SQL 标准的要求。

postgreSQL 字符类型

NameDescription
character varying(n), varchar(n)变长,有长度限制
character(n), char(n)定长,不足补空白
text变长,无长度限制

长度区别

varchar(n) 和 char(n) 分别是 character varying(n) 和 character(n) 的别名,没有声明长度的 character 等于 character(1) ;character varying 不带长度使用 ,那么该类型接受任何长度的字符串。后者是 PostgreSQL 的扩展。

另外,PostgreSQL 提供 text 类型,它可以存储任何长度的字符串。尽管text类型不是 SQL 标准,但是许多 SQL 数据库系统也有它。

物理存储

character 类型的数据,在物理上都用空格(原文: space)填充到指定长度 n 并且以这种方式存储和显示。不过,填充的空白在是无语意的。

在比较两个 character 值的时候,填充的空白都会被忽略,在转换成其它字符串类型的时候,character 值里面的空格会被删除。请注意,在 character varying 和 text 类型的数据里,结尾的空白是有语意的。

这些类型的存储需求是 4 字节加上实际的字符串,如果是 character 的话再加上填充的字节(上面提到的空格)。

长字符串将会自动被系统压缩,因此在磁盘上的物理需求可能会更少些。长字符串也会存储在后台表里面,这样它们就不会干扰对短字段的快速访问(我的理解是:磁盘寻址路径或者次数更少?有知道的还望指出!!!)。不管怎样,允许存储的最长字符串大概是 1GB 。

允许在数据类型声明中出现的 n 的最大值小于该最大值。更改此值不是很有用,因为使用多字节字符编码时,字符和字节数可能会完全不同。

如果你想存储没有特定上限的长字符串,那么使用 text 或没有长度声明词的 character varying ,而不要设定长度限制。

性能差异

这三种类型之间没有性能差别,只不过是在使用 character 的时候增加了存储尺寸。

虽然在某些其它的数据库系统里,character(n) 有一定的性能优势,但在 PostgreSQL 里没有。

在大多数情况下,应该使用 text 或 character varying 。

参考:pg 8.2.23文档

Postgresql的character varying = bytea问题

Java开发Postgresql 数据库兼容应用的问题,与oracle有一些不同:

Java类型映射数据库类型的不同,Oracle jdbc驱动程序处理Java String类型可正常映射到数据库的Numberic(Integer),而Postgres则会出错。

另外,则是使用hibernate时经常的错误: operator不存在:character varying = bytea问题,不要被这个描述误导了,并不是sql语句中character varying = bytea类型的比较,而是当使用hibernate使用参数绑定,而参数的值为null时,hibernate或者Postgresql驱动将这个参数 映射为varbinary类型,Postgresql将varbinary认为为bytea类型

以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Postgresql数据库character varying和character的区别说明

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Postgresql数据库character varying和character的区别说明

目录PostgreSQL character varying和character的区别SQL 标准postgreSQL 字符类型Ppythonostgresql的character varying = bytea问题Postgresql c
2022-07-08

postgreSQL数据库to_timestamp和to_date的区别

1 SELECT  to_timestamp("2020-02-27 12:12:12","yyyy-MM-dd hh24:mi:ss") ;2 SELECT  to_date("2020-02-27 12:12:12","yyyy-MM-dd hh24:mi
postgreSQL数据库to_timestamp和to_date的区别
2020-07-29

React函数组件和类组件的区别及说明

这篇文章主要介绍了React函数组件和类组件的区别及说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2022-11-13

redis数据库和mysql数据库的区别

差异化对比:redis 是基于内存的键值存储,数据访问速度极快,通常用于缓存等场景;mysql 是关系型数据库,数据存储在硬盘上,适用于需要持久化存储和强大查询功能的场景。Redis 和 MySQL 数据库的区别Redis 和 MySQL
redis数据库和mysql数据库的区别
2024-04-19

oracle数据库和mysql的区别

oracle数据库和mysql都是基于关系模型的数据库,但oracle在兼容性、可扩展性、数据类型和安全性方面更胜一筹;而mysql则侧重速度和灵活性,更适合小到中等规模的数据集。①oracle提供广泛的数据类型,②提供高级安全功能,③适合
oracle数据库和mysql的区别
2024-05-10

Zabbix系统MySQL数据库分区表的设定--精简说明

Zabbix监控中对后台MySQL DB几张历史大表依照时间进行分区无疑可以提高zabbix by时间查询时的性能,可以在zabbix后台DB在安装之初就将table设定为分区表,也可以在使用一段时间后已经有时间的情况下设定table为分区
2023-06-04

云服务器和数据库的区别和联系与区别

云服务器和数据库都是用来存储和处理数据的系统,但它们的区别是很大的。云服务器是一种虚拟服务器,它的功能是让客户机或者用户可以连接到服务器进行数据访问。而数据库则是一个存储着数据的系统,它的作用是用来管理和维护数据,以便于在需要的时候可以从这些数据中提取出有用的信息来支持业务。云服务器可以使用虚拟化技术来提高效率,例如使用云计算平台来减少硬件成本和管理负担。云服务器还可以提供更快的数据访问速度和
2023-10-26

云服务器和数据库的区别

云服务器和数据库都是常用的网络存储和数据库服务,它们之间有一些相似之处,但又有一些区别。以下是它们之间的一些区别和联系:区别:用途:云计算通常用于提供虚拟化、存储、网络和数据保护等服务,这些服务可以在不同的服务器和操作系统之间迁移和管理数据,并提供更灵活的计算、存储和网络资源。基础架构:云计算通常使用分布式架构,例如微服务架构、容器化部署等,来提高应用程序的扩展性和可用性,并通过集群和
2023-10-26

hadoop和数据库的区别有哪些

Hadoop是一个开源的分布式计算框架,主要用于处理大规模数据的存储和分析,而数据库是用于管理和存储结构化数据的软件系统。Hadoop是基于文件系统的存储方式,将数据分散存储在不同的节点上,而数据库则使用表结构存储数据。Hadoop是用于处
hadoop和数据库的区别有哪些
2024-03-14

帝国cms所有的数据库表结构和字段说明

帝国CMS也是比较有名气的,基本上没有出现安全问题。但是帝国CMS后台的逻辑和布局,感觉太复杂。如果我们需要会员或者下载等交互功能,这一点的扩展上帝国是有优势的。这篇文章主要介绍了帝国cms所有的数据库表结构和字段说明,需要的朋友可以参考下。
2023-05-17

编程热搜

目录