PostgreSQL字段类型说明
SERIAL8
存储自动递增的惟一整数,最多 8 字节。
BIT
固定长度的位串。
BIT VARYING(n)
VARBIT(n)
可变长度的位串,长度为 n 位。
BOOLEAN
存储逻辑布尔值(true/false/unknown),可以是 TRUE、t、true、y、yes 和 1,或者 FALSE、f、false、n、no 和 0。
BYTEA
用于存储大型二进制对象(比如图形)的原始二进制数据。使用的存储空间是 4 字节加上二进制串的长度。
CHAR(n)
CHARACTER(n)
包含固定长度的字符串,用空格填充到长度 n。
DATE
用 4 字节的存储空间存储日历日期(年、月、日)。
DATETIME
存储日历日期和天内的时间。
DECIMAL(p,s)
NUMERIC(p,s)
存储精确的数值,精度(p)和刻度(s)为 0 或更高。
FLOAT4
REAL
存储浮点数,精度为 8 或更低和 6 个小数位。
FLOAT8
DOUBLE PRECISION
存储浮点数,精度为 16 或更低和 15 个小数位。
SMALLINT
存储有符号或无符号 2 字节整数。
INTEGER
存储有符号或无符号 4 字节整数。
INT8
BIGINT
存储有符号或无符号 8 字节整数。
SERIAL
SERIAL4
存储自动递增的惟一整数值,最多 4 字节存储空间。
TEXT
存储长度可变的大型字符串数据,最多 1 GB。PostgreSQL 自动压缩 TEXT 字符串。
TIME (WITHOUT TIME ZONE |
WITH TIME ZONE)
存储天内的时间。如果不存储数据库服务器的时区,就使用 8 字节的存储空间;如果存储时区,就使用 12 字节。
TIMESTAMP (WITHOUT TIME ZONE |
WITH TIME ZONE)
存储日期和时间。可以存储或不存储数据库服务器的时区,使用 8 字节存储空间。
VARCHAR(n)
CHARACTER VARYING(n)
CHARACTER VARYING
存储可变长度的字符串,最大长度为 n。不存储末尾的空格。
类似Oracle ,PostgreSQL也有强大的类型转换函数, 下面仅举两个类型转换例子。
--1 例子
postgres=# select 1/4;
?column?
----------
0
(1 row)
在PG里如果想做除法并想保留小数,用上面的方法却行不通,因为"/" 运算结果为取整,并
且会截掉小数部分。
--2 类型转换
postgres=# select round(1::numeric/4::numeric,2);
round
-------
0.25
(1 row)
备注:类型转换后,就能保留小数部分了。
--3 也可以通过 cast 函数进行转换
postgres=# select round( cast ( 1 as numeric )/ cast( 4 as numeric),2);
round
-------
0.25
(1 row)
--4 关于 cast 函数的用法
postgres=# SELECT substr(CAST (1234 AS text), 3,1);
substr
--------
3
(1 row)
--5 附: PostgreSQL 类型转换函数
| Function | Return Type | Description | Example |
|---|---|---|---|
|
to_char ) |
text | convert time stamp to string | to_char(current_timestamp, 'HH12:MI:SS') |
| to_char ( interval, text ) |
text | convert interval to string | to_char(interval '15h 2m 12s', 'HH24:MI:SS') |
| to_char ( int, text ) |
text | convert integer to string | to_char(125, '999') |
|
to_char precision |
text | convert real/double precision to string | to_char(125.8::real, '999D9') |
| to_char ( numeric, text ) |
text | convert numeric to string | to_char(-125.8, '999D99S') |
| to_date (text, text ) |
date | convert string to date | to_date('05 Dec 2000', 'DD Mon YYYY') |
| to_number ( text, text ) |
numeric | convert string to numeric | to_number('12,454.8-', '99G999D9S') |
| to_timestamp ( text, text ) |
timestamp with time zone | convert string to time stamp | to_timestamp('05 Dec 2000', 'DD Mon YYYY') |
| to_timestamp ( double precision ) |
timestamp with time zone | convert Unix epoch to time stamp | to_timestamp(1284352323) |
| 1 | varchar | java.lang.String | 12 | |
| 2 | bpchar | java.lang.String | 1 | |
| 3 | cidr | java.lang.Object | 1,111 | |
| 4 | inet | java.lang.Object | 1,111 | |
| 5 | macaddr | java.lang.Object | 1,111 | |
| 6 | text | java.lang.String | 12 | |
| 7 | int8 | java.lang.Long | -5 | |
| 8 | int8 | java.lang.Long | -5 | |
| 9 | box | java.lang.Object | 1,111 | |
| 10 | circle | java.lang.Object | 1,111 | |
| 11 | float8 | java.lang.Double | 8 | |
| 12 | int4 | java.lang.Integer | 4 | |
| 13 | interval | java.lang.Object | 1,111 | |
| 14 | line | java.lang.Object | 1,111 | |
| 15 | lseg | java.lang.Object | 1,111 | |
| 16 | money | java.lang.Double | 8 | |
| 17 | numeric | java.math.BigDecimal | 2 | |
| 18 | path | java.lang.Object | 1,111 | |
| 19 | point | java.lang.Object | 1,111 | |
| 20 | polygon | java.lang.Object | 1,111 | |
| 21 | float4 | java.lang.Float | 7 | |
| 22 | int2 | java.lang.Integer | 5 | |
| 23 | int4 | java.lang.Integer | 4 | |
| 24 | time | java.sql.Time | 92 | |
| 25 | timestamp | java.sql.Timestamp | 93 | |
| 26 | bit | java.lang.Boolean | -7 | |
| 27 | varbit | java.lang.Object | 1,111 | |
| 28 | bool | java.lang.Boolean | -7 | |
| 29 | bytea | [B | -2 |
PostgreSQL字段类型说明的更多相关文章
- PostgreSQL 中字段类型varchar
PostgreSql数据库中varchar类型与sql server中字段用法有差别,PostgreSql中如果字段设置为varchar类型长度为10,则无论存字母.数字或其它符号,长度最大为10个, ...
- PostgreSQL 的字段类型和表操作笔记
字段类型 数值类型 Name Storage Size Description Range smallint 2 bytes small-range integer -32768 to +32767 ...
- PostgreSQL 修改字段类型从int到bigint
由于现在pg的版本,修改int到bigint仍然需要rewrite表,会导致表阻塞,无法使用.但可以考虑其他方式来做.此问题是排查现网pg使用序列的情况时遇到的. 由于int的最大值只有21亿左右,而 ...
- 主流数据库字段类型转.Net类型的方法
最近在阅读一些开源的代码,发现其中有些方法总结的很全面,至少在我做同样的事情时候,需要抓破脑袋想活着google,现在看到了这个关于主流数据库字段类型转.Net类型的方法,故收藏之,也顺便分享给那些能 ...
- postgreSQL-如何查数据库表、字段以及字段类型、注释等信息?
之前从网上也搜索了一些关于postgreSQL的系统表含义以及如何查表相关信息,但是都没有一个完整的内容,所以自己将找到的一些内容作了下整合,大家可以根据自己需要再对sql进行调整. --1.查询对象 ...
- django中模型详解-字段类型与约束条件
这片博文来详细说明django模型的使用,涉及到django模型的创建,字段介绍,以及django模型的crud操作,以及一对一等操作. 在使用模型之前,我们首先设置数据库选项,django的默认数据 ...
- postgresql数字类型
postgresql的数据类型很多,也可以使用create type命令创建自定义数据类型,但常用的数据类型是以下三种: l 数字数据类型 l 字符串数据类型 l 日期/时间数据类型 数字数据类 ...
- Django ORM中常用的字段类型以及参数配置
一.数值型 AutoField对应int(11).自增主键,Django Model默认提供,可以被重写. BooleanField对应tinyint(1).布尔类型字段,一般用于记录状态标记. De ...
- Django中的常用字段类型与参数
Django中的常用字段类型 1. 数值型 以下都是数值相关的,比如AutoField,它在MySQL中的类型为int(11),而BooleanField在MySQL中对应的类型是tinyint(1) ...
随机推荐
- Dubbo高级篇4
https://blog.csdn.net/moonpure/article/details/52842115 线程模型 http://dubbo.io/User+Guide-zh.htm 用户指南& ...
- Matlab中要显示数学公式或符号Latex
\rho 代表 ρ, \sigma 代表 σ \alpha α \beta β \gamma γ \delta δ \epsilon ϵ \zeta ζ \eta ...
- 5G的真正价值
导读 5G时代已经到来,它究竟会给我们的工作和生活带来什么样的改变?5G的爆点,究竟会出现在哪里?我们又该如何把握5G带来的发展机遇? 进入2019年之后,5G的商用步伐在不断加快.全球各地,都在忙着 ...
- 【POJ 3476】A Game with Colored Balls
POJ 3476 首先写了个treap,然后常数太大tle了... 然后想了个极为复杂的方法,是一共7个dsu,3个bit,还有一个set.然后写了一半就歇菜了... 然后看dxm的方法,是这样做的: ...
- wifidog源码分析 - 客户端检测线程
引言 当wifidog启动时,会启动一个线程(thread_client_timeout_check)维护客户端列表,具体就是wifidog必须定时检测客户端列表中的每个客户端是否在线,而wifido ...
- 7-(基础入门篇)关于STM32底层程序使用说明
https://www.cnblogs.com/yangfengwu/p/9357695.html 基础教程源码链接请在淘宝介绍中下载,由于链接很容易失效,如果失效请联系卖家,谢谢 https://i ...
- Codeforces round 1083
Div1 526 这个E考试的时候没调出来真的是耻辱.jpg A 求个直径就完事 #include<cstdio> #include<algorithm> #include&l ...
- CF1101G (Zero XOR Subset)-less 线性基
传送门 既然每一次选择出来的都是一个子段,不难想到前缀和计算(然而我没有想到--) 设异或前缀和为\(x_i\),假设我们选出来的子段为\([1,i_1],(i_1,i_2],...,(i_{k-1} ...
- Luogu4546 THUWC2017 在美妙的数学王国中畅游 LCT、泰勒展开
传送门 题意:反正就是一堆操作 LCT总是和玄学东西放在一起我们不妨令$x_0=0.5$(其实取什么都是一样的,但是最好取在$[0,1]$的范围内),将其代入给出的式子,我们得到的$f(x)$的式子就 ...
- 重装系统之制作U盘启动盘
准备: 1.需要一个大于4G的U盘. 2.一个原版系统. 3.制作U盘启动盘的工具—ultraliso. 一.一个大于4G的U盘 制作启动盘将会格式化U盘,记得做好备份. 二.一个原版系统 至于你要装 ...