Postgres 的 Range 类型
mysql 不支持 Range 类型
零、介绍
1、 适用场景:
a.可以用于实现 是否满足薪资需求
的功能
b.可以用于实现 是否符合上线时间
的功能
一、定义
1、Postgres SQL + Sequelize
Postgres | Sequelize |
---|---|
4 位整数范围, int4range | Sequelize.RANGE(Sequelize.INTEGER) |
8 位整数范围, int8range | Sequelize.RANGE(Sequelize.BIGINT) |
数值范围, numrange | Sequelize.RANGE(Sequelize.DECIMAL) |
无时区的时间戳范围, tsrange | |
有时区的时间戳范围, tstzrange | Sequelize.RANGE(Sequelize.DATE) |
日期范围, daterange | Sequelize.RANGE(Sequelize.DATEONLY) |
题外话:我们常用的是日期类型是
tstzrange
,即有时区的时间戳范围
,比如我们在中国的 2018-07-31 的 21 点整存入,数据库即显示为2018-07-31 21:00:00.000+08
CREATE TABLE "Students"
(
name VARCHAR(255),
expected_salary int4range,
)
这边我们定义了一个学生表,有“姓名”和“期望薪资”两个字段。
二、存
1、Postgres SQL
INSERT INTO "Students"
VALUES
(
'colin',
'xxx'
)
xxx 的值形如:
a. '(1000,2000]'
b. '[null,2000)'
注:
1、遵循()
为开[]
为闭的原则
2、null
表示无限值
2、Sequelize
(1)普通写法
a. [
{ value: 1000, inclusive: false },
{ value: 2000, inclusive: true }
]
b. [
{ value: null, inclusive: true },
{ value: 2000, inclusive: false }
]
注:inclusive: true 表示闭,inclusive: fasle 表示开。
(2)省略写法
a.[1001, 2000]
b.[null, 2000]
注:遵循
()
为开[]
为闭的原则,但在 Sequelize 里,虽然是两元素数组的形式,即[]
,但实际上右边的]
还是表示)
的意思。
三、取
1、Postgres SQL
形如:[1001,2000)
注:格式始终为
[)
,即如果存的是[]
,取出来会被转化成[)
。
2、Sequelize
形如:
[
{ value: 1000, inclusive: false },
{ value: 2000, inclusive: true }
]
四、 QUERY
1、Postgres SQL
(1)查询范围的最低和最高值
upper()
、lower()
SELECT upper(expected_salary), lower(expected_salary) FROM "Students" where id = 13;
return:
upper lower
2 1
(2)检查某个值是否在给定范围内
SELECT expected_salary @> 4000 FROM "Students" where id = 13;
return:
t
2、Sequelize
sequelize 并不直接支持(上面)方便的 query
参考资料
1.[Postgres 9.2 新特性之:范围类型 (Range Types)] https://www.oschina.net/translate/postgres-9-2-highlight-range-types?print
Postgres 的 Range 类型的更多相关文章
- Postgres空间地理类型POINT POLYGON实现附近的定位和电子围栏功能
目录 需求和背景 安装插件postgis 点POINT类型和距离 表添加POINT类型 添加空间索引 插入点 两个点之间的距离 附近5公里内的点 最近的10个点 面多边形'POLYGON' 添加字段类 ...
- Postgres 的 Array 类型
mysql 不支持 Array 类型 一.Postgres 原生SQL 适用场景:可以用于实现贴标签功能 1.定义 CREATE TABLE "Students" ( name V ...
- range类型(Python)
range 不是 iterator >>> R = range(3) >>> next(R) Traceback (most recent call last): ...
- 为什么range不是迭代器?range到底是什么类型?
迭代器是 23 种设计模式中最常用的一种(之一),在 Python 中随处可见它的身影,我们经常用到它,但是却不一定意识到它的存在.在关于迭代器的系列文章中(链接见文末),我至少提到了 23 种生成迭 ...
- python学习之:序列类型 之列表,元组,range
列表 列表是可变序列,通常用于存放同类项目的集合(其中精确的相似程度将根据应用而变化). class list([iterable]) 可以用多种方式构建列表: 使用一对方括号来表示空列表: [ ] ...
- Python数据类型之“序列概述与基本序列类型(Basic Sequences)”
序列是指有序的队列,重点在"有序". 一.Python中序列的分类 Python中的序列主要以下几种类型: 3种基本序列类型(Basic Sequence Types):list. ...
- JS 之DOM range对象
DOM范围 DOM中的range对象是DOM2中新定义的接口.通过这个对象可以选择文档中的某个区域,而不必考虑节点的界限. 创建范围 document.createRange()创建一个范围,这个范围 ...
- oracle interval-partition 解决range分区大难题
博客<oracle分区>中讲了oracle的几种分区,并且对于oracle的典型分区如Range分区和List分区给了示例. 在实际运用Range分区时,遇到了这样的难题: createt ...
- HTML5每日一练之input新增加的5种其他类型1种标签应用
今天介绍input在HTML5中的最后5种类型,分别是:number,range,search,tel和color 注意:此种类型的input在Opera10+中效果为佳,Chrome中效果不是十分好 ...
随机推荐
- css兼容技巧
CSS兼容常用技巧 请尽量用xhtml格式写代码,而且DOCTYPE影响 CSS 处理,作为W3C标准,一定要加DOCTYPE声明. 1.div的垂直居中问题 vertical-align:middl ...
- usart下位机输出使用printf的格式化技巧
输出使用printf("0x%3X ", I2c_Buf_Write[i]);时,上位机接收过程,使用文本格式,显示结果如下 虽然是保留了三位的宽度,但是并不美观. 相比于使用pr ...
- Sprign中常用注解
1.@Component 创建类对象,相当于配置<bean/> 2.@Service 与 @Component功能相同 2.1写在ServiceImpl类上 (建议在ServiceImpl ...
- Hadoop3集群搭建之——hive添加自定义函数UDF
上篇: Hadoop3集群搭建之——虚拟机安装 Hadoop3集群搭建之——安装hadoop,配置环境 Hadoop3集群搭建之——配置ntp服务 Hadoop3集群搭建之——hive安装 Hadoo ...
- De Bruijn序列
最近文章中经常出现及De Bruijin 这个关键字,网上搜索了一下,记录下来. De Bruijn序列 (德布鲁因序列) 问题:能否构造一个长度为2的n次方的二进制环状串,使得二进制环状串中总共2的 ...
- apache ab工具
Apache ab并发负载压力测试 ab命令原理 Apache的ab命令模拟多线程并发请求,测试服务器负载压力,也可以测试nginx.lighthttp.IIS等其它Web服务器的压力. ab命令 ...
- JAVA遇上HTML-----JSP 篇基本概念
Java Web简介 1.什么是WEB应用程序: Web应用程序是一种可以通过Web访问的应用程序.Web应用程序的一个最大好处是用户很容易访问应用程序.用户只需要有浏览器即可,不需要再安装其他软件. ...
- Tomcat服务器的安装和配置
一.Tomcat下载 可以直接从Apache的网站上下载Tomcat(http://tomcat.apache.org/),进入首页后,在左边Download一栏可选择你要下载的版本,点击便可进入To ...
- Promise.all函数的使用
Promise.all([this.getCity('guess'),this.getCity('hot'),this.getCity('group')]).then(res=>{ // con ...
- pageshow和pagehide事件
Firefox和opera有一个特性,往返缓存:可以在用户使用浏览器的后退和前进按钮时加快页面的转换速度,这个缓存不仅保存了页面的数据,还有DOM和JavaScript的状态. 为了更形象的说明bfc ...