6 PostgreSQL函数

6.2 数学函数

  • abs(x) 绝对值

  • pi() 圆周率π

    select abs(-3),pi();

    • cookie:

      MySQL中的pi()默认值3.141593,

      PostgreSQL中的pi()默认值3.14159265358979

      e值默认值位数不同,一般浮点数未设置保留

      位数显示会不同,MySQL保留6位
  • sqrt(x) 平方根

  • mod(x,y) x被y除后的余数

    select sqrt(4),mod(9.0,4);

  • ceil(x) ceiling(x) 返回不小于x的最小整数值

  • floor(x) 返回不大于x的最大整数

    select ceil(3.3),floor(3.3);

  • round(x) 返回最接近x的整数,即四舍五入

  • round(x,y) 返回最接近x的数,其值保留小数点后y位

    select round(5.5),round(5.5,2);

  • sign(x) 正 零 负 => 1 0 -1

    select sign(pi()),sign(0),sign(-3);

  • pow(x,y) power(x,y) 返回x的y次方

  • exp(x) e的x次方

    select pow(2,3),exp(1);

  • log(x) 返回x相对于10的对数

    select log(10),log(3);

  • log(x,y) 返回x相对于y的对数

    • cookie:

      MySQL中log(x)返回的是x相对于e的对数
  • radians(x) 将角度转换为弧度

  • degrees(x) 将弧度转换为角度

    select radians(45),degrees(0.5*pi());

  • sin(x) x的正弦,其中x为弧度值

  • asin(x) x的反正弦,x值在-1到1范围之内,否则报错

  • cos(x) x的余弦,其中x为弧度值

  • acos(x) x的反余弦,x值在-1到1范围之内,否则报错

  • tan(x) x的正切,其中x为弧度值

  • atan(x) x的反正切,其中x为弧度值

  • cot(x) x的余切

    select sin(1),round(sin(pi()));

6.3 字符串函数

  • char_length(str)

    返回str所包含的字符个数

    select char_length('good');

  • concat(s1,s2,...)

    返回结果为连接参数产生的字符串

    select concat('|**',now(),'**|');

  • concat_ws(x,s1,s2,...)

    返回*为分隔符连接后面参数的字符串

    select concat_ws('*','1st','null','3rd');

  • left(s,n)

    返回字符串s开始最左边n个字符

  • right(s,n)

    返回字符串s最右边n个字符

    select left('123456',2),right('123456',2);

  • lpad(s1,len,s2)

    返回字符串s1,其左边由字符串s2填充,填充长度为len

  • rpad(s1,len,s2)

    返回字符串s1,其左边由字符串s2填充,填充长度为len

    select lpad('123',4,'456'),rpad('123',2,'456');

  • ltrim(s)

    返回字符串s,字符串左侧空格被删除

  • rtrim(s)

    返回字符串s,字符串右侧空格被删除

  • trim(s)

    返回字符串s,字符串两侧空格被删除

  • trim(s1 from s)

    返回字符串s,字符串两侧s1被删除

    select trim('a' from 'aa11aa');

  • repeat(s,n)

    返回一个重复n次s组成的字符串,n<=0则为空字符串,s或n

    为null则返回null

    select repeat('|*|',3);

  • replace(s,s1,s2)

    返回s字符串,s其中s1被s2替换

    select replace('aabbcc','b','d');

  • substring(s,n,len)

    从字符串s返回一个长度为len,起始于位置n

    select substring('123456',4,4);

    • cookie:

      PostgreSQL10 不支持n为负数,即倒数位置
  • position(str1 in str)

    返回字符串srl1在字符串str中的开始位置

    select position('ball' in 'football');

  • reverse(s)

    将字符串s反转返回

    select reverse('football');

6.4 日期时间函数

  • current_date

    将当前时间按 YYYU-MM-DD 格式返回

    select current_date;

  • current_time

    将当前时间按 HH:MM:SS 格式返回

    select current_time;

  • curent_timestamp\localtimestamp\now()

    返回当前时间和日期

  • extract(type from date)

    从日期中提取一部分,而不是执行日期运算

    select extract(day from now()); //日

    select extract(month from now());//月

    select extract(year from now()); //年

    select extract(doy from now());//一年的第几天

    select extract(dow from now()); //星期几

    select extract(quarter from now()); //季度

    • cookie:

      此函数和MySQL中的extract略有不同

日期和时间的运算操作

select date '2019-1-17'-'1993-12-22'

6.5 条件判断函数

  • case expr when v1 then r1 [when v2 r2] [else rm] end;

    如果expr等于某个vn,就返回对应位置的rn的值,

    如果expr与所有的值都不相等,就返回rm

    select case 2 when 1  then 'one'
    when 2 then 'two' else 'more' end;
  • case when v1 then r1 [when v2 then r2] [else rm] end;

    如果vn的某个值为true,就返回对应位置的rn的值,

    如果都不为true,就返回rm

6.6 系统信息函数

  • version()

    获取PostgreSQL版本号

    select version();

  • user current_user

    返回当前被PostgreSQL服务器验证的用户名

    select user,current_user;

    • cookie:

      在MySQL中version()同样获取mysql版本号,

      没有user\current_user函数

6.7 加密和解密函数

  • md5(str)

    为字符串算出一个MD5 128比特检查和

    select md5('mypwd');

  • encode(str,pswd_str)

    使用pswd_str作为加密编码,加密str

    常见加密编码base64\hex\escape

  • decode(str,pswd_str)

    使用pswd_str作为密码,解密str

    select encode ('secret','hex');

    select decode ('736563726574','hex');

    • cookie:

      MySQL中没有encode\decode函数

6.8 改变数据类型

  • cast(x,as type) 将x转换成type类型

    select cast(100 as char(5));

PostgreSQL自学笔记:6 PostgreSQL函数的更多相关文章

  1. Node.js自学笔记之回调函数

    写在前面:如果你是一个前端程序员,你不懂得像PHP.Python或Ruby等动态编程语言,然后你想创建自己的服务,那么Node.js是一个非常好的选择.这段时间对node.js进行了简单的学习,在这里 ...

  2. PostgreSQL自学笔记:1 初识 PostgreSQL

    博主教材:李小威.清华大学出版社.<PostgreSQL 9.6 从零开始学> 博主操作系统系统:Windows10 博主PostgreSQL版本:PostgreSQL 9.6 和 Pos ...

  3. PostgreSQL自学笔记:9 索引

    9 索引 9.1 索引简介 索引是对数据库表中一列或多列值进行排序的一种结构,使用 索引可提高数据库中特定数据的查询速度 9.1.1 索引的含义和特点 索引是一种单独的.存储在磁盘上的数据库结构,他们 ...

  4. PostgreSQL自学笔记:8 查询数据

    8 查询数据 8.1 基本查询语句 select语句的基本格式是: select {* | 字段1[,字段2,...]} [ from 表1,表2... [where 表达式] [group by & ...

  5. PostgreSQL自学笔记:与python交互

    与python交互教程 原文地址:https://www.yiibai.com/html/postgresql/2013/080998.html 1. Python psycopg2 模块APIs 连 ...

  6. PostgreSQL自学笔记:5 数据类型和运算符

    5 数据类型和运算符 5.1 PostgreSQL 数据类型介绍 5.1.1 整数类型 整型类型 字节 取值范围 smallint 2字节 -2^15 ~ 2^15 int integer 4字节 - ...

  7. PostgreSQL自学笔记:3 数据库的基本操作

    3 数据库的基本操作 3.1 创建数据库 3.1.1 使用对象浏览器创建数据库 [Server] -> PostgreSQL 9.6 -> 数据库,右击 -> 创建 通常: 数据库: ...

  8. PostgreSQL学习笔记——内置函数

    算术函数(数值计算) +(加).-(减).*(乘)./(除) ABS函数--绝对值: ABS(数值) MOD--求余: MOD(被除数,除数) ROUND--四舍五入: ROUND(对象数值,保留小数 ...

  9. PostgreSQL自学笔记:7 插入、更新与删除数据

    7 插入.更新与删除数据 7.1 插入数据 先创建表person: create table person( id int not null, name char(40) not null defau ...

随机推荐

  1. mac/Linux/centos ssh连接服务器以及跳板机,实现类型Xshell 功能

    1. 由于之前一段时间,公司测试服务器需要有跳板机这种操作,由于mac机器上没有类似Xshell这种程序,所以,只能自己造轮子啦. 本程序采用Shell+Expect脚本编写 具体代码请查看:http ...

  2. Vue(项目踩坑)_解决vue中axios请求跨域的问题

    一.前言 今天在做项目的时候发现axios不能请求跨域接口 二.主要内容 1.之前直接用get方式请求聚合数据里的接口报错如下 2.当前请求的代码 3.解决方法 (1)在项目目录中依次找到:confi ...

  3. MAC OS进阶必看——这10个技巧让你秒变MAC达人

    文章内容及图片来源于:什么值得买,如果涉及版权问题,请联系作者删除 文章收录于:风云社区(提供上千款各类mac软件的下载) 使用mac系统也有好几个年头,出色的办公效率以及越来越广的兼容性让mac成为 ...

  4. python 线程/线程锁/信号量

    单线程 #常规写法 import threading import time def sayhi(num): # 定义每个线程要运行的函数 print("running on number: ...

  5. Kubernetes之Deployment控制器

    Deployment 简介 deployment 是用来管理无状态应用的,面向的集群的管理,而不是面向的是一个不可变的个体,举例:有一群鸭子,要吃掉一个,只需要再放一个新的鸭仔就好了,不会影响什么,而 ...

  6. Mybatis-批量执行

    一.使用动态SQL 中的 Foreach 批量插入 1.MySQL // 实体类 public class MyUser { private Integer id; private String na ...

  7. MySQL学习笔记(一)Ubuntu16.04中MySQL安装配置(5.6优化、错误日志、DNS解决)

    目录 第一部分.5.6安装.配置.自动备份 第二部分.5.7源码安装.配置.自动备份 第一部分.5.6安装 1.安装mysql sudo apt-get install mysql-server su ...

  8. latex beamer 添加页码

    导言中加 \setbeamertemplate{footline}[frame number]

  9. [数学笔记Mathematical Notes]2-一个带对数的积分不等式

    定理. $$\bex \int_0^1\frac{\ln^2x}{x^x}\rd x<2\int_0^1 \frac{\rd x}{x^x}. \eex$$ 证明: 由分部积分及 Fubini ...

  10. Java之final关键字详解

    1. 修饰类 当用final去修饰一个类的时候,表示这个类不能被继承. 注意: a. 被final修饰的类,final类中的成员变量可以根据自己的实际需要设计为fianl. b. final类中的成员 ...