postgresql整理

数据类型:

整型: smallint integer bigint

任意精度数值: numeric(precision,scale) 精度、刻度

浮点型: real

序号类型(自增): serial bigserial

字符类型:varchar(n) char(n)text

日期类型:timestamp8字节 2013-05-17 13:01:38.437925

Interval 12字节 555283:40:10

date 4字节2013-05-17

time 8字节13:01:53.890859

数组类型:integer[] 存储 array[21000,22000,23000,24000]

函数

数学函数

函数

返回类型

描述

例子

结果

abs(x)

绝对值

abs(-17.4)

17.4

cbrt(double)

立方根

cbrt(27.0)

3

ceil(double/numeric)

不小于参数的最小的整数

ceil(-42.8)

-42

degrees(double)

把弧度转为角度

degrees(0.5)

28.6478897565412

exp(double/numeric)

自然指数

exp(1.0)

2.71828182845905

floor(double/numeric)

不大于参数的最大整数

floor(-42.8)

-43

ln(double/numeric)

自然对数

ln(2.0)

0.693147180559945

log(double/numeric)

10为底的对数

log(100.0)

2

log(b numeric,x numeric)

numeric指定底数的对数

log(2.0,64.0)

6.0000000000

mod(y,x)

取余数

mod(9,4)

1

pi()

double

"π"常量

pi()

3.14159265358979

power(a double,b double)

double

ab次幂

power(9.0,3.0)

729

power(a numeric,b numeric)

numeric

ab次幂

power(9.0,3.0)

729

radians(double)

double

把角度转为弧度

radians(45.0)

0.785398163397448

random()

double

0.01.0之间的随机数值

random()

round(double/numeric)

圆整为最接近的整数

round(42.4)

42

round(v numeric,s int)

numeric

圆整为s位小数数字

round(42.438,2)

42.44

sign(double/numeric)

参数的符号(-1,+1)

sign(-8.4)

-1

sqrt(double/numeric)

平方根

sqrt(2.0)

1.4142135623731

trunc(double/numeric)

截断(向零靠近)

trunc(42.8)

42

trunc(v numeric,s int)

numeric

截断为s小数位置的数字

trunc(42.438,2)

42.43

三角函数

函数

描述

acos(x)

反余弦

asin(x)

反正弦

atan(x)

反正切

atan2(x,y)

正切 y/x 的反函数

cos(x)

余弦

cot(x)

余切

sin(x)

正弦

tan(x)

正切

字符串函数

函数

返回类型

描述

例子

结果

string || string

text

字串连接

'Post' || 'gresql'

Postgresql

char_length(string)

int

字串中的字符个数

char_length('jose')

4

convert(string using conversion_name)

text

使用指定的转换名字改变编码。

convert('Postgresql' using iso_8859_1_to_utf8)

'Postgresql'

lower(string)

text

把字串转化为小写

lower('TOM')

tom

overlay(string placing string from int [for int])

text

替换子字串

overlay('Txxxxas' placing 'hom' from 2 for 4)

Thomas

substring(string [from int] [for int])

text

抽取子字串

substring('Thomas' from 2 for 3)

hom

substring(string from pattern)

text

抽取匹配 POSIX正则表达式的子字串

substring('Thomas' from '...$')

mas

trim([leading | trailing | both] [characters] from string)

text

从字串string的开头/结尾/两边/删除只包含characters(缺省是一个空白)的最长的字串

trim(both 'x' from 'xTomxx')

Tom

upper(string)

text

把字串转化为大写。

upper('tom')

TOM

btrim(string text [,characters text])

text

string开头和结尾删除只包含在characters(缺省是空白)的字符的最长字串

btrim('xyxtrimyyx','xy')

trim

length(string text)

int

string中字符的数目

length('jose')

4

lpad(string text,length int [,fill text])

text

通过填充字符fill(缺省时为空白),把string填充为长度length如果string已经比length长则将其截断(在右边)

lpad('hi',5,'xy')

xyxhi

ltrim(string text [,characters text])

text

从字串string的开头删除只包含characters(缺省是一个空白)的最长的字串。

ltrim('zzzytrim','xyz')

trim

replace(string text,from text,to text)

text

把字串string里出现地所有子字串from替换成子字串to

replace('abcdefabcdef','cd','XX')

abXXefabXXef

rpad(string text,fill text])

text

通过填充字符fill(缺省时为空白),把string填充为长度length。如果string已经比length长则将其截断。

rpad('hi','xy')

hixyx

rtrim(string text [,character text])

text

从字串string的结尾删除只包含character(缺省是个空白)的最长的字

rtrim('trimxxxx','x')

trim

split_part(string text,delimiter text,field int)

text

根据delimiter分隔string返回生成的第field个子字串(1 Base)

split_part('abc~@~def~@~ghi','~@~',2)

def

strpos(string,substring)

text

声明的子字串的位置。

strpos('high','ig')

2

substr(string,from [,count])

text

抽取子字串。

substr('alphabet',3,2)

ph

translate(string text,to text)

text

把在string中包含的任何匹配from中的字符的字符转化为对应的在to中的字符。

translate('12345','14','ax')

a23x5

数据格式函数

函数

返回类型

描述

例子

to_char(timestamp,text)

text

把时间戳转换成字串

to_char(current_timestamp,'HH12:MI:SS')

to_char(interval,text)

text

把时间间隔转为字串

to_char(interval '15h 2m 12s','HH24:MI:SS')

to_char(int,text)

text

把整数转换成字串

to_char(125,'999')

to_char(double precision,text)

text

把实数/双精度数转换成字串

to_char(125.8::real,'999D9')

to_char(numeric,text)

text

numeric转换成字串

to_char(-125.8,'999D99S')

to_date(text,text)

date

把字串转换成日期

to_date('05 Dec 2000','DD Mon YYYY')

to_timestamp(text,text)

timestamp

把字串转换成时间戳

to_timestamp('05 Dec 2000','DD Mon YYYY')

to_timestamp(double)

timestamp

UNIX纪元转换成时间戳

to_timestamp(200120400)

to_number(text,text)

numeric

把字串转换成numeric

to_number('12,454.8-','99G999D9S')

日期/时间函数

函数

返回类型

描述

例子

结果

age(timestamp,timestamp)

interval

减去参数,生成一个使用年、月的"符号化"的结果

age('2001-04-10',timestamp '1957-06-13')

43 years 9 mons 27 days

age(timestamp)

interval

current_date减去得到的数值

age(timestamp '1957-06-13')

43 years 8 mons 3 days

current_date

date

今天的日期

current_time

time

现在的时间

current_timestamp

timestamp

日期和时间

date_part(text,timestamp)

double

获取子域(等效于extract)

date_part('hour',timestamp '2001-02-16 20:38:40')

20

date_part(text,interval)

double

获取子域(等效于extract)

date_part('month',interval '2 years 3 months')

3

date_trunc(text,timestamp)

timestamp

截断成指定的精度

date_trunc('hour',timestamp '2001-02-16 20:38:40')

2001-02-16 20:00:00+00

extract(field from timestamp)

double

获取子域

extract(hour from timestamp '2001-02-16 20:38:40')

20

extract(field from interval)

double

获取子域

extract(month from interval '2 years 3 months')

3

localtime

time

今日的时间

localtimestamp

timestamp

日期和时间

now()

timestamp

当前的日期和时间(等效于 current_timestamp)

timeofday()

text

当前日期和时间

EXTRACT、date_part函数支持的field:

描述

例子

结果

DAY

(月分)里的日期域(1-31)

EXTRACT(DAY from TIMESTAMP '2001-02-16 20:38:40');

16

DOW

每周的星期号(0-6;星期天是0) (仅用于timestamp)

EXTRACT(DOW FROM TIMESTAMP '2001-02-16 20:38:40');

5

DOY

一年的第几天(1 -365/366) (仅用于 timestamp)

EXTRACT(DOY from TIMESTAMP '2001-02-16 20:38:40');

47

HOUR

小时域(0-23)

EXTRACT(HOUR from TIMESTAMP '2001-02-16 20:38:40');

20

MICROSECONDS

秒域,包括小数部分,乘以 1,000,000

EXTRACT(MICROSECONDS from TIME '17:12:28.5');

28500000

MILLISECONDS

秒域,包括小数部分,乘以 1000

EXTRACT(MILLISECONDS from TIME '17:12:28.5');

28500

MINUTE

分钟域(0-59)

EXTRACT(MINUTE from TIMESTAMP '2001-02-16 20:38:40');

38

MONTH

对于timestamp数值,它是一年里的月份数(1-12);对于interval数值,它是月的数目,然后对12取模(0-11)

EXTRACT(MONTH from TIMESTAMP '2001-02-16 20:38:40');

2

QUARTER

该天所在的该年的季度(1-4)(仅用于 timestamp)

EXTRACT(QUARTER from TIMESTAMP '2001-02-16 20:38:40');

1

SECOND

秒域,包括小数部分(0-59[1])

EXTRACT(SECOND from TIMESTAMP '2001-02-16 20:38:40');

40

WEEK

该天在所在的年份里是第几周。

EXTRACT(WEEK from TIMESTAMP '2001-02-16 20:38:40');

7

YEAR

年份域

EXTRACT(YEAR from TIMESTAMP '2001-02-16 20:38:40');

2001

数组函数;

函数

返回类型

描述

例子

结果

array_cat(anyarray,anyarray)

anyarray

连接两个数组

array_cat(ARRAY[1,2,3],ARRAY[4,5])

{1,4,5}

array_append(anyarray,anyelement)

anyarray

向一个数组末尾附加一个元素

array_append(ARRAY[1,2],3)

{1,3}

array_prepend(anyelement,anyarray)

anyarray

向一个数组开头附加一个元素

array_prepend(1,ARRAY[2,3])

{1,3}

array_dims(anyarray)

text

返回一个数组维数的文本表示

array_dims(ARRAY[[1,[4,6]])

[1:2][1:3]

array_lower(anyarray,int)

int

返回指定的数组维数的下界

array_lower(array_prepend(0,ARRAY[1,3]),1)

0

array_upper(anyarray,int)

int

返回指定数组维数的上界

array_upper(ARRAY[1,4],1)

4

array_to_string(anyarray,text)

text

使用提供的分隔符连接数组元素

array_to_string(ARRAY[1,'~^~')

1~^~2~^~3

string_to_array(text,text)

text[]

使用指定的分隔符把字串拆分成数组元素

string_to_array('xx~^~yy~^~zz','~^~')

{xx,yy,zz}

聚合函数:

1. AVG 返回指定组中的平均值,空值被忽略。
 例:select prd_no,avg(qty) from sales group by prd_no

2. COUNT 返回指定组中项目的数量
 例:select count(prd_no) from sales 

3. MAX 返回指定数据的最大值。
 例:select prd_no,max(qty) from sales group by prd_no 

4. MIN 返回指定数据的最小值。
 例:select prd_no,min(qty) from sales group by prd_no

5. SUM 返回指定数据的和,只能用于数字列,空值被忽略。
 例:select prd_no,sum(qty) from sales group by prd_no

6. COUNT_BIG 返回指定组中的项目数量,与COUNT函数不同的是COUNT_BIG返回bigint值,而COUNT返回的是int值。
 例:select count_big(prd_no) from sales

7. GROUPING 产生一个附加的列,当用CUBEROLLUP运算符添加行时,输出值为1.当所添加的行不是由CUBEROLLUP产生时,输出值为0.
 例:select prd_no,sum(qty),grouping(prd_no) from sales group by prd_no with rollup

8. BINARY_CHECKSUM 返回对表中的行或表达式列表计算的二进制校验值,用于检测表中行的更改。
 例:select prd_no,binary_checksum(qty) from sales group by prd_no

9. CHECKSUM_AGG 返回指定数据的校验值,空值被忽略。
 例:select prd_no,checksum_agg(binary_checksum(*)) from sales group by prd_no

10. CHECKSUM 返回在表的行上或在表达式列表上计算的校验值,用于生成哈希索引。

11. STDEV 返回给定表达式中所有值的统计标准偏差。
 例:select stdev(prd_no) from sales

12. STDEVP 返回给定表达式中的所有值的填充统计标准偏差。
 例:select stdevp(prd_no) from sales

13. VAR 返回给定表达式中所有值的统计方差。
 例:select var(prd_no) from sales

14. VARP 返回给定表达式中所有值的填充的统计方差。
 例:select varp(prd_no) from sales

15.统计各部门的总薪水,平均薪水和部门的详细情况

SELECTsum(salary) OVER (PARTITION by depname),avg(salary) OVER (PARTITION bydepname),*from empsalary;


16.统计人员在所在部门的薪水排名情况

select rank()over(partition by depname ORDER BY salary),* from empsalary;



select row_number() over(PARTITION by depnameorder by salary desc),* from empsalary;


为每一行指派一个唯一的编号。使用此函数替代 NUMBER 函数


select rank() over(partition by depname orderby salary desc),* from empsalary;

计算一个值在一组值中的排位。如果出现并列的情况,RANK 函数会在排名序列中留出空位。


select dense_rank() over(partition by depnameorder by salary desc),* from empsalary;

计算值在分区中的排位。对于并列的值,DENSE_RANK 函数不会在排名序列中留出空位。



select percent_rank() over(partition bydepname order by salary desc),* from empsalary;

根据rank()排序的第X行减去1除于组中总记录-1.

select cume_dist() over(partition by depnameorder by salary desc),* from empsalary;

计算某个值在一组行中的相对位置。


select ntile(3) over (partition by depnameorder by salary desc),* from empsalary;

1到当前值,除以分组的的数量,尽可能使分布平均

select lag(salary,NULL) over(partition bydepname order by salary desc),* from empsalary;

偏移量函数,取滞后值,lag(column_name,0)表示字段偏移量为2,没有则用default值代替,这里是0,不写默认是null

select first_value(salary) over(partition bydepname order by salary desc),* from empsalary;

从窗口第一行返回值。

注释

FIRST_VALUE函数使您不用自连接就能(依照某种排序)选择表中的第一个值。如果您希望使用第一个值作为计算的基准,此函数很有价值。

FIRST_VALUE函数从窗口提取第一个记录。然后针对第一个记录计算expression并返回结果。

如果指定 IGNORE NULL,则返回expression的第一个非 NULL 值。如果指定 RESPECT NULLS(缺省值),则会返回第一个值,无论其是否为 NULL。

FIRST_VALUE 函数与其它大多数集合函数的不同之处在于:该函数只能与窗口说明一起使用。


select last_value(salary) over (partition bydepname ),* from empsalary;

从窗口最后一行返回值。

注释

LAST_VALUE函数使您不用自连接就能(依照某种排序)选择表中的最后一个值。如果您希望使用最后一个值作为计算的基准,此函数很有价值。

LAST_VALUE函数在完成 ORDER BY 后从分区提取最后一个记录。然后针对最后一个记录计算expression并返回结果。

如果指定 IGNORE NULL,则返回expression的最后一个非 NULL 值。如果指定 RESPECT NULLS(缺省值),则会返回最后一个值,无论其是否为 NULL。

LAST_VALUE函数与其它大多数集合函数的不同之处在于:该函数只能与窗口说明一起使用。


select nth_value(salary,2) over (partition by depname order by salary),* fromempsalary;

返回窗口框架中的指定值,如nth_value(salary,2),则表示返回字段salary的第二个窗口函数

主意last_value()和first_value()函数的运用,当使用order by 只会对当前行排序。例如:


修改为order by的范围:

相关文章

来源:http://www.postgres.cn/docs/11/ 4.1.1. 标识符和关键词 SQL标识符和关键词必须以一个...
来源:http://www.postgres.cn/docs/11/ 8.1. 数字类型 数字类型由2、4或8字节的整数以及4或8...
来源:http://www.postgres.cn/docs/11/ 5.1. 表基础 SQL并不保证表中行的顺序。当一个表被读...
来源:http://www.postgres.cn/docs/11/ 6.4. 从修改的行中返回数据 有时在修改行的操作过程中...
来源:http://www.postgres.cn/docs/11/ 13.2.1. 读已提交隔离级别 读已提交是PostgreSQL中的...
来源:http://www.postgres.cn/docs/11/ 9.7. 模式匹配 PostgreSQL提供了三种独立的实现模式匹...