PostgreSQL中的N''和::bpchar使用
作者:雨临Lewis
文章主要介绍了在SQL中不同字符串类型的使用和区别,包括N'、::bpchar、VARCHAR(n)、CHAR(n)和TEXT等,并通过示例展示了它们在查询结果中的表现
PostgreSQL N''和::bpchar
N’'的效果和::bpchar效果类似
都表示定长字符串。
比如下边的sql:
select n'233' as num; select '233'::bpchar as num; select '233' as num;
以上sql都会得到’233’的结果集。
但是对于前两条sql拿到的字符串是bpchar类型,相当于MySQL的char类型;而第三条sql拿到的字符串是text类型。
- VARCHAR(n) varchar 指定了最大长度,变长字符串,不足定义长度的部分不补齐。
- CHAR(n) bpchar 定长字符串,实际数据不足定义长度时,以空格补齐。
- TEXT text 没有特别的上限限制(仅受行的最大长度限制)
对于::bpchar
其实更多表示的是转型,比起N’’,还可以这样使用:
select 233 as num; select 233::bpchar as num;
- 第一条sql拿到的是数值类型,
- 第二条sql拿到的是字符串,233这个数值被转型成bpchar类型
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。