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中效果不是十分好 ...
随机推荐
- 扩展方法(深入理解c#)
1. 静态类到扩展方法: 许多方法可能都适合转为扩展方法,只要具有以下特征: 1)你想为一个类型添加一些成员: 2)你不需要为类型的实例添加更多的数据: 3)你不能改变类型本身,因为是别人的代码 2. ...
- sqlserver中如何将mdf文件还原到数据库
- css扩大超链接的点击范围
给a标签设置display:block后,它会根据盒模型计算a标签的实际大小.这时候,你可以使用hover伪类使a的整个盒模型生效..link a{display:block;padding:2px ...
- hdu-1034(模拟+小朋友分糖)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1034 参考文章:https://blog.csdn.net/zyy173533832/article/ ...
- Unable to fetch some archives ,maybe run apt-get update or try with --fix-missing?
今天在liunx下要解压zip包时,发现系统里面没有装unzip包,于是就运行sudo apt-get install unzip,可是总是没办法安装,于是上网找原因,有的说源文件需要修改,于是就运行 ...
- python模块:pickle
"""Create portable serialized representations of Python objects. See module copyreg f ...
- idea的maven项目不知道为啥下载不下来jar包,看本地仓库只是下载了一下xml文件,没有jar包问题
确认了私服上的jar包能直接下载下来,而且jar包是正常的:但是就是不能通过idea下载,通过idea下载到本地仓库的只生成了.lastUpdated文件,检查了setting.xml文件.网络,私服 ...
- hadoop Hive 的建表 和导入导出及索引视图
1.hive 的导入导出 1.1 hive的常见数据导入方法 1.1.1 从本地系统中导入数据到hive表 1.创建student表 [ROW FORMAT DELIMITED]关键字,是用来设 ...
- 好文推荐系列--------(1)bower---管理你的客户端依赖
好文原文地址:http://segmentfault.com/a/1190000000349555 编者注:我们发现了比较有趣的系列文章<30天学习30种新技术>,准备翻译,一天一篇更新, ...
- jquery页面隐藏和展开之间切换
html页面: <p id="myp4">默认情况下,这段话是隐藏的,点击按钮以后,这段话就展开,并且按钮上的值改变</p> <button id=& ...