PostgreSQL 数据类型介绍(一)

  • 查看当前数据库的数据类型
postgres=# \d pg_type ;
        Table "pg_catalog.pg_type"
     Column     |     Type     | Modifiers 
----------------+--------------+-----------
 typname        | name         | not null
 typnamespace   | oid          | not null
----
//显示所有的type类型以及对应的存储类型:
postgres=# select typname, typstorage  from pg_type ;
                typname                | typstorage 
---------------------------------------+------------
 bool                                  | p
 bytea                                 | x
 char                                  | p
 name                                  | p
 int8                                  | p
 int2                                  | p
 int2vector                            | p
 int4                                  | p
 regproc                               | p
 text                                  | x
 oid                                   | p
 tid                                   | p
 xid                                   | p
 cid                                   | p
 oidvector                             | p
 pg_type                               | x
 pg_attribute                          | x
 pg_proc                               | x
 pg_class                              | x
 json                                  | x
 xml                                   | x
 _xml                                  | x

关于存储类型 p x e m 的含义 ,请自行搜索,代表了各自 不同的存储方式。



  左侧为数据类型的分类
Paste_Image.png
  • 常见的数据类型,数字
Paste_Image.png

关于 serial类型,效果其实和integer + next sequence 一样。
当你创建了 serial 数据类型,其实也帮你自动创建了 序列

postgres=# create table t (id serial);
CREATE TABLE

postgres=# \d+ t
                                             Table "public.t"
 Column |  Type   |                   Modifiers                    | Storage | Stats target | Description 
--------+---------+------------------------------------------------+---------+--------------+-------------
 id     | integer | not null default nextval('t_id_seq'::regclass) | plain   |              | 
可以看出,自动创建了 t_id_seq 这个序列,同时添加了 not null 约束。

研究下这个序列:
postgres=# \d+ t_id_seq
               Sequence "public.t_id_seq"
    Column     |  Type   |        Value        | Storage 
---------------+---------+---------------------+---------
 sequence_name | name    | t_id_seq            | plain
 last_value    | bigint  | 1                   | plain
 start_value   | bigint  | 1                   | plain
 increment_by  | bigint  | 1                   | plain
 max_value     | bigint  | 9223372036854775807 | plain
 min_value     | bigint  | 1                   | plain
 cache_value   | bigint  | 1                   | plain
 log_cnt       | bigint  | 0                   | plain
 is_cycled     | boolean | f                   | plain
 is_called     | boolean | f                   | plain
Owned by: public.t.id

  • 常见的字符类型
Paste_Image.png

SQL 定义了两种基本的字符类型,varchar(n)和char(n),这里的n是一个正整数。两种类型都可以存储最多n个字符长的字串,试图存储更长的字串到这些类型的字段里会产生一个错误,除非超出长度的字符都是空白,这种情况下该字串将被截断为最大长度。如果没有长度声明,char等于char(1),而varchar则可以接受任何长度的字串。
char 类型,如果不够长度用 空格填充。

         注意 无论是那种字符集,这里和的单位是 字符,而不是字节,和 ORACLE不同。

text:表面是无限长度,其实最大可以支持到1个GB(依据版本而定)

           下面都是和字节有关的类型,上面则是和字符有关的类型

“char” 单字节的内部使用的类型
name 内部使用的类型

postgres=# create table t2(c1 varchar(3));
字段 c1 最多允许3个“字符”,不是字节!!
CREATE TABLE
postgres=# insert into t2 values ('你好呀');
INSERT 0 1
postgres=# insert into t2 values ('abc');
INSERT 0 1
postgres=# insert into t2 values ('abcd');
这时候就报错了,因为abcd是4个字符。
ERROR:  value too long for type character varying(3)

postgres=# select  pg_column_size (c1),c1 from t2 ;
 pg_column_size |   c1   
----------------+--------
             10 | 你好呀
              4 | abc
(2 rows)

-常用的事件类型

Paste_Image.png

interval :是一个时间间隔类型。

Paste_Image.png

时间的输出格式

Paste_Image.png
postgres=# show datestyle; 
 DateStyle 
-----------
 ISO, MDY
(1 row)

postgres=# select now() ;
              now              
-------------------------------
 2017-05-26 09:32:35.197556+08   指的是8区
(1 row)

interval 类型:

postgres=# select now()-current_date;
?column?     
-----------------
 09:35:29.864559
(1 row)
Paste_Image.png
  • Boolean 类型
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 200,045评论 5 468
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 84,114评论 2 377
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 147,120评论 0 332
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,902评论 1 272
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,828评论 5 360
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,132评论 1 277
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,590评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,258评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,408评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,335评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,385评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,068评论 3 315
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,660评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,747评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,967评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,406评论 2 346
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,970评论 2 341

推荐阅读更多精彩内容