sql数据类型

数据类型

数值类型

整数型

类型名称存储空间(字节)范围
TINYINT10~255
SMALLINT2-32768 ~ +32767
INTEGER(最常见int)4-2,147,483,648 ~ +2,147,483,647
BINARY_INTEGER4-2,147,483,648 ~ +2,147,483,647
BIGINT8-9,223,372,036,854,775,808 ~ 9,223,372,036,854,775,807

浮点型

类型名称存储空间(字节)
REAL,FLOAT4(单精度)4
DOUBLE PRECISION,FLOAT8(双精度)8
FLOAT§4
BINARY_DOUBLE(其实是上面的DOUBLE,PRECISION的别名,只是它兼容oracle类型)8
DEC[(p[,s])]INTEGER(p[,s])视情况而定,看用户声明的精度,>8

序列整型(都是正整数)

类型名称存储空间(字节)范围
SMALLSERIAL21 ~ 32,767
SERIAL41 ~ 2,147,483,647
BIGSERIAL81 ~ 9,223,372,036,854,775,807

任意精度型

类型名称存储空间(字节)
NUMERIC[(p[,s])]DECIMAL(p[,s])视情况而定,看用户声明的精度,>8
NUMBER[(p[,s])](和上面浮点型像,它也是NUMERIC类型的别名,为兼容Oracle数据类型视情况而定,看用户声明的精度,>8

货币类型

类型名称存储空间(字节)范围
money8-92233720368547758.08 到 +92233720368547758.07

numeric,int和bigint类型的值可以转化为money类型。如果从real和double precision类型转换到money类型,可以先转化为numeric类型,再转化为money类型

但是不建议浮点数转换为货币类型,因为小数点位数会有四舍五入等,日积月累转为货币类型出入就会很大。

money类型的值可以转换为numeric类型不丢失精度。

SELECT '52093.89'::money::numeric::float8;

当一个money类型的值除以另一个money类型的值时,结果是double precision(是一个数值类型,不是货币类型)

布尔类型

类型名称存储空间(字节)取值
BOOLEAN1真:true假:falsenull值会引起unknown

运算:

false and true= false | false or true = true

unknown and true = unknown | unknown or true = true

unknown and false = false | unknown or false = unknown

not unknown = unknown | not true = false | not false = true

字符类型

所属类型名称存储空间(字节)
定长字符串CHAR(n)·n(由人为定义,精度n)不足补空格·当不带n时,默认精度为1。最大10MB
CHARACTER(n)
NCHAR(n)
变长字符串VARCHAR(n)n表示字节长度,最大10MB
CHARACTER最大10MB
TEXT最大为1G-8023B(即1073733621B)

特殊字符类型

name 存储空间64字节(63个可用字节+1个结束符)使用时需要将name类型转化为text类型,不然有可能出现字符截断的情况

"char" 存储空间1字节 主要用于系统表,主要作为简单化的枚举类型使用。

日期/时间类型

类型名称存储空间(字节)表达
DATE(日期)4yyyy-mm-dd
TIME§8p表示小数点后的精度,取值范围为0~6hh:mm:ss.nnnnnnn
reltime(相对间隔时间)4X years X mons X days XX:XX:XX

在这里插入图片描述

先set datastyle,再进行插入 不然有歧义会报错
在这里插入图片描述
同时我们发现虽然说我们插入的是02-10-2022,但是系统自动补全时间,所以说虽然存储空间是4字节但是实际存储空间大小为8字节

可以带时区 WITH TIME ZONE

不带时区 WITHOUT TIME ZONE

日期输入方式 也需要注意DateStyle

MDY "月-日-年"

DMY "日-月-年"

YMD "年-月-日"

注意模式不同,相对位置不同,可能会有歧义。

特殊的可以输入today,yesterday,tomorrow,系统读取的时候会转换为普通的data

时间输入

记得在建表的时候设置的数据类型是带时区还是不带时区的,根据设置的数据类型对时间输入进行加或者不加时区

时区输入

可以输入

完整时区名称 如Asia/Shanghai

太平洋标准时间(PST)

ISO 8601与PST的偏移 如-8:00 -800 -8

二进制类型

类型名称存储空间(字节)
BLOB(不可用于列存,仅支持部分的外部存储接口)mysql中blob是什么 - 数据库 - 亿速云最大为1G-8203字节
RAW(变长的十六进制类型,同样的也不可用于列存)4字节加上实际的十六进制字符串。最大为1G-8203字节。
BYTEA(变长的二进制字符串)4字节加上实际的二进制字符串。最大为1G-8203字节。

blob如果设置了列,插入数据时可以设置empty_blob()

通常要插入raw数据时,用函数hextoraw()****:十六进制字符串转换为 raw

因为** raw 是十六进制,所以说不能出现比 f **更大的字母

几何类型

最基本的类型:点

因为其他的类型都是以点为基础

名称存储空间(字节)表现形式
point(点)16(x,y)
lseg(线段)32((x1,y1),(x2,y2))
box(矩形,虽然与线段的表达形式一样,但是完全不一样)32((x1,y1),(x2,y2))
path16+16n((x1,y1),…)闭合路径,即第一个点和最后一个点连接[(x1,y1),…]开放路径,第一个点和最后一个点不连接
polygon(多边形(和闭合路径有点像))40+16n((x1,y1),…)
circle(圆)24<(x,y),r>

注意box矩形的两个点是一对对角点

XML类型和JSON类型的区别比较

同:XML和JSON是最常见的两种数据交换格式,存储的数据都可以存储为text,数据可读性 差不多,可扩展性也差不多

异: XML** ( Extensible Markup Language )扩展标记语言**,格式统一,符合标准。容易 与其他系统进行远程交互,数据共享方便。但是XML文件庞大文件格式复杂,传输占带 宽。客户端不同浏览器之间解析XML的方式不一致,需要重复编写很多代码,解析花费 较多资源和时间。

JSON** (JavaScript Object Notation)**,数据格式简单,易于读写,格式是压缩的,所占 带宽小。相比XML易于解析,容易对JSON数据进行读取。支持多种语言,简化了服务器端和 客户端的代码开发量,但是现在JSON在web中推广还属于初级阶段,没有XML通用性高

  • 4
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

xin_L_

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

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

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

打赏作者

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

抵扣说明:

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

余额充值