国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數(shù)據(jù)庫 > PostgreSQL > 正文

介紹PostgreSQL中的范圍類型特性

2020-10-29 21:50:08
字體:
供稿:網(wǎng)友

 PostgreSQL 9.2 的一項(xiàng)新特性就是范圍類型 range types,通過這個(gè)名字你可以輕松猜出該類型的用途,它可讓你為某列數(shù)據(jù)定義數(shù)值范圍。

這個(gè)簡單的特性可以讓我們不需要定義兩個(gè)字段來描述數(shù)值的開始值和結(jié)束值,一個(gè)最直觀的例子就是:
 

postgres# CREATE TABLE salary_grid (id int, position_name text, start_salary int, end_salary int);CREATE TABLEpostgres# INSERT INTO salary_grid VALUES (1, 'junior developper', 20000, 30000);INSERT 0 1postgres# INSERT INTO salary_grid VALUES (2, 'senior developper', 28000, 35000);INSERT 0 1postgres# INSERT INTO salary_grid VALUES (3, 'postgres developper', 50000, 70000);INSERT 0 1

這個(gè)簡單的關(guān)系用于存儲(chǔ)一個(gè)給定的職位和待遇的范圍(你還需要確定工資的貨幣單位),重要的是你必須實(shí)現(xiàn)一些系統(tǒng)函數(shù)或者外部程序 API 來執(zhí)行例如范圍的交叉或者聯(lián)合。


Postgres 9.2 允許你的應(yīng)用直接在數(shù)據(jù)庫端實(shí)現(xiàn)范圍值,范圍類型包括:

  •     4 位整數(shù)范圍, int4range
  •     8 位整數(shù)范圍, int8range
  •     數(shù)值范圍, numrange
  •     無時(shí)區(qū)的時(shí)間戳范圍, tsrange
  •     帶時(shí)間戳的時(shí)間范圍, tstzrange
  •     日期范圍, daterange

你也可以定義自己的范圍類型,Postgre 官網(wǎng)文檔給出了 float 的示例:
 

postgres# CREATE TYPE floatrange AS RANGE (postgres# subtype = float8,postgres# subtype_diff = float8mi);

有了這樣一個(gè)功能,我們前面提到的工資表格例子就可以改為:
 

postgres=# create table salary_grid (id int, position_name text, salary_range int4range);CREATE TABLEpostgres=# INSERT INTO salary_grid VALUES (1, 'junior developper', '[20000, 30000]');INSERT 0 1postgres=# INSERT INTO salary_grid VALUES (2, 'senior developper', '[28000, 35000]');INSERT 0 1postgres=# INSERT INTO salary_grid VALUES (3, 'postgres developper', '[50000, 70000]');INSERT 0 1postgres=# select * from salary_grid;id | position_name | salary_range----+---------------------+---------------1 | junior developper | [20000,30001)2 | senior developper | [28000,35001)3 | postgres developper | [50000,70001)(3 rows)

很重要的一點(diǎn)是,如果使用的是括號(hào)(),元組數(shù)據(jù)的上界是排除在外的,而中括號(hào)[]則上界包含其中。

數(shù)據(jù)庫本身也包含不同的用于處理范圍類型的函數(shù)。

你可直接獲取一個(gè)給定范圍的最低和最高值:
 

postgres=# SELECT upper(salary_range), lower(salary_range) FROM salary_grid;upper | lower-------+-------30001 | 2000035001 | 2800070001 | 50000(3 rows)

你可以檢查某個(gè)值是否包含在給定范圍內(nèi):
 

postgres=# SELECT salary_range @> 4000 as checkpostgres=# FROM salary_gridpostgres=# WHERE position_name = 'junior developper';check-------f(1 row)

這里顯示 4000 并不包含在初級(jí)職位的待遇里 [20000,30000].


這里稍微復(fù)雜了一些,你還可以檢查兩個(gè)范圍之間的重疊的部分,這里的 salary_range 使用的是 int4,因此 int4range 函數(shù)可用于此操作:
 

postgres=# WITH junior_salary AS ( SELECT salary_range as junior FROM salary_grid WHERE position_name = 'junior developper'),senior_salary AS ( SELECT salary_range as senior FROM salary_grid WHERE position_name = 'senior developper')SELECT int4range(junior) && int4range(senior) as check FROM junior_salary, senior_salary;check-------t(1 row)

這里顯示的是初級(jí)和高級(jí)職位之間的工資重疊部分。

你還可以設(shè)定無上下限的范圍類型,或者是只有上限或者下限的范圍類型,讓我們來看一個(gè)非常現(xiàn)實(shí)的例子:
 

postgres# UPDATE salary_grid SET salary_range = '[50000,)' WHERE position_name = 'postgres developper';UPDATE 0 1postgres=# SELECT salary_range @> 60000000 as checkpostgres-# FROM salary_grid WHERE position_name = 'postgres developper';check-------t(1 row)

你可以使用 lower_inf 或者 upper_inf 來檢查范圍的無限值。

Postgres 還有其他一些內(nèi)嵌的函數(shù)(如 isempty),這個(gè)可以直接從官方文檔中獲取詳細(xì)信息。

你還可以閱讀《PostgreSQL 的數(shù)組》

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 临泉县| 广东省| 古蔺县| 锡林浩特市| 赤壁市| 和硕县| 毕节市| 丹凤县| 新蔡县| 嵊泗县| 越西县| 大庆市| 威海市| 儋州市| 常山县| 宣化县| 瑞安市| 景德镇市| 宣恩县| 南阳市| 濉溪县| 正定县| 盘山县| 呼和浩特市| 井冈山市| 迁西县| 勃利县| 霍山县| 吉安市| 玛纳斯县| 宜宾市| 双江| 海门市| 肥东县| 涿鹿县| 古蔺县| 漠河县| 鹿邑县| 息烽县| 广安市| 普宁市|