欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

介紹PostgreSQL中的范圍類型特性

 更新時(shí)間:2015年04月21日 10:00:34   投稿:goldensun  
這篇文章主要介紹了介紹PostgreSQL中的范圍類型特性,范圍類型特性自9.2版本開始加入,需要的朋友可以參考下

 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 TABLE
postgres# INSERT INTO salary_grid VALUES (1, 'junior developper', 20000, 30000);
INSERT 0 1
postgres# INSERT INTO salary_grid VALUES (2, 'senior developper', 28000, 35000);
INSERT 0 1
postgres# 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 TABLE
postgres=# INSERT INTO salary_grid VALUES (1, 'junior developper', '[20000, 30000]');
INSERT 0 1
postgres=# INSERT INTO salary_grid VALUES (2, 'senior developper', '[28000, 35000]');
INSERT 0 1
postgres=# INSERT INTO salary_grid VALUES (3, 'postgres developper', '[50000, 70000]');
INSERT 0 1
postgres=# 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 | 20000
35001 | 28000
70001 | 50000
(3 rows)

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

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

這里顯示 4000 并不包含在初級職位的待遇里 [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)

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

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

postgres# UPDATE salary_grid SET salary_range = '[50000,)' WHERE position_name = 'postgres developper';
UPDATE 0 1
postgres=# SELECT salary_range @> 60000000 as check
postgres-# 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ù)組》

相關(guān)文章

  • 在PostgreSQL中使用數(shù)組時(shí)值得注意的一些地方

    在PostgreSQL中使用數(shù)組時(shí)值得注意的一些地方

    這篇文章主要介紹了在PostgreSQL中使用數(shù)組時(shí)值得注意的一些地方,包括如何提高輸入性能,需要的朋友可以參考下
    2015-04-04
  • HQL查詢語言的使用介紹

    HQL查詢語言的使用介紹

    HQL是Hibernate Query Language的縮寫,語法很想SQL,但是HQL是一種面向?qū)ο蟮牟樵冋Z言。SQL的操作對象是數(shù)據(jù)列、表等數(shù)據(jù)庫對象,而HQL操作的是類、實(shí)例、屬性
    2013-10-10
  • Doris Join 優(yōu)化原理文檔詳解

    Doris Join 優(yōu)化原理文檔詳解

    這篇文章主要為大家介紹了Doris Join 優(yōu)化原理文檔詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-10-10
  • Hive日期格式轉(zhuǎn)換方法總結(jié)

    Hive日期格式轉(zhuǎn)換方法總結(jié)

    這篇文章主要為大家介紹了Hive日期格式轉(zhuǎn)換方法總結(jié),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-06-06
  • DBeaver一款替代Navicat的數(shù)據(jù)庫可視化工具

    DBeaver一款替代Navicat的數(shù)據(jù)庫可視化工具

    這篇文章主要介紹了DBeaver一款替代Navicat的數(shù)據(jù)庫可視化工具,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-11-11
  • DeepinV20快速安裝Mariadb的詳細(xì)步驟

    DeepinV20快速安裝Mariadb的詳細(xì)步驟

    本文給大家介紹DeepinV20安裝Mariadb的詳細(xì)步驟,MariaDB數(shù)據(jù)庫管理系統(tǒng)是MySQL的一個(gè)分支,添加一些功能支持本地的非阻塞操作和進(jìn)度報(bào)告,具體內(nèi)容詳情跟隨小編一起看看吧
    2021-07-07
  • 數(shù)據(jù)庫sql查詢性能優(yōu)化詳解

    數(shù)據(jù)庫sql查詢性能優(yōu)化詳解

    這篇文章主要介紹了數(shù)據(jù)庫sql查詢性能優(yōu)化詳解,查詢優(yōu)化的本質(zhì)是讓數(shù)據(jù)庫優(yōu)化器為SQL語句選擇最佳的執(zhí)行計(jì)劃,對于大型的應(yīng)用系統(tǒng),大量的數(shù)據(jù)當(dāng)然需要效率最快的執(zhí)行語句,需要的朋友可以參考下
    2023-07-07
  • 數(shù)據(jù)庫設(shè)計(jì)的完整性約束表現(xiàn)在哪些方面

    數(shù)據(jù)庫設(shè)計(jì)的完整性約束表現(xiàn)在哪些方面

    數(shù)據(jù)完整性是指數(shù)據(jù)的正確性、完備性和一致性,是衡量數(shù)據(jù)庫質(zhì)量好壞的規(guī)范。數(shù)據(jù)庫完整性由各式各樣的完整性約束來確保,因而可以說數(shù)據(jù)庫完整性規(guī)劃即是數(shù)據(jù)庫完整性約束的規(guī)劃。那么,數(shù)據(jù)庫設(shè)計(jì)的完整性約束表現(xiàn)哪些方面?
    2015-10-10
  • 在windows上用docker?desktop安裝部署StoneDB

    在windows上用docker?desktop安裝部署StoneDB

    這篇文章主要介紹了在windows上用docker?desktop安裝部署StoneDB的相關(guān)資料,整個(gè)過程記錄的十分詳細(xì),推薦給大家,需要的朋友可以參考下
    2022-08-08
  • 解決Navicat數(shù)據(jù)庫連接成功但密碼忘記的問題

    解決Navicat數(shù)據(jù)庫連接成功但密碼忘記的問題

    這篇文章給大家介紹了Navicat數(shù)據(jù)庫連接成功,密碼忘記如何解決,文中給大家介紹了兩種解決方法,有詳細(xì)的圖文講解,需要的朋友可以參考下
    2023-08-08

最新評論