MySQL & PostgreSQL 常用数据类型

MySQL & PostgreSQL

MySQL: 全球最受欢迎的开源数据库

PostgreSQL: 全球最先进的开源关系数据库

本文章所有资料均来自 MySQL 5.7 文档1与 PostgreSQL 10 文档2

常用数据类型

数字类型

整数类型

数据类型 MySQL PostgreSQL
INT2 SMALLINT 的别名 SMALLINT 的别名
SMALLINT 2 字节整数,SMALLINT(6) 的别名* 2 字节整数
INT 4 字节整数,INT(11) 的别名* INTEGER 的别名
INT4 INT 的别名 INTEGER 的别名
INTEGER INT 的别名 4 字节整数
BIGINT 8 字节整数,BIGINT(20) 的别名* 8 字节整数
INT8 BIGINT 的别名 BIGINT 的别名

*在MySQL中,SMALLINT、INT和BIGINT的参数为显示宽度。

字节数 范围 范围
1 (-27, 27-1) (-128, 127)
2 (-215, 215-1) (-32768, 32767)
4 (-231, 231-1) (-2147483648, 2147483647)
8 (-263, 263-1) (-9223372036854775808, 9223372036854775807)

定点数类型(任意精度)

数据类型 MySQL PostgreSQL
DEC DECIMAL 的别名 NUMERIC 的别名
DEC(precision, scale = 0) DECIMAL(precision, scale) 的别名 NUMERICL(precision, scale) 的别名
DECIMAL DECIMAL(10) 的别名 NUMERIC 的别名
DECIMAL(precision, scale = 0) 可选精度的精确数字precision: (0, 65), scale: (0, 30) NUMERICL(precision, scale) 的别名
NUMERIC DECIMAL 的别名 精确数字
NUMERIC(precision, scale = 0) DECIMAL(precision, scale) 的别名 可选精度的精确数字precision: (0, 1000), scale: (0, 1000)

(precision >= scale),其中 precision 为数字位数,scale 为小数位数。

浮点数类型

数据类型 MySQL PostgreSQL
FLOAT 单精度浮点数 (4 字节) DOUBLE PRECISION 的别名
FLOAT(precision) FLOAT 的别名,precision: (0, 24) REAL 的别名,precision: (1, 24)
DOUBLE 的别名*precision: (25, 53) DOUBLE PRECISION 的别名,precision: (25, 53)
FLOAT4 FLOAT 的别名 REAL 的别名
REAL DOUBLE 的别名* 单精度浮点数 (4 字节)
DOUBLE PRECISION DOUBLE 的别名* 双精度浮点数 (8 字节)
FLOAT8 DOUBLE 的别名* DOUBLE PRECISION 的别名

precision 为以二进制位表示的最低可接受精度。

*在MySQL中,DOUBLE为双精度浮点数(8字节)。

序数类型

数据类型 MySQL PostgreSQL
SERIAL BIGINT UNSIGNED NOT NULL AUTO_INCREMENT UNIQUE 的别名 INTEGER NOT NULL DEFAULT nextval('tablename_colname_seq') 的别名*

*在PostgreSQL中,会在创建表格之前创建名为tablename_colname_seq的序列生成器,创建表格之后将该序列与tablename表的colname列相关联。

布尔类型

数据类型 MySQL PostgreSQL
BOOL TINYINT(1) 的别名* BOOLEAN 的别名
BOOLEAN TINYINT(1) 的别名* 逻辑布尔值(真/假)
  • 5
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

砂漠的毒虫

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值