postgresql常见开发技巧

1.数据类型

名字描述
bigint有符号 8 字节整数
bigserial自增八字节整数
bit [ (n) ]定长位串
bit varying [ (n) ]变长位串
boolean逻辑布尔量 (真/假)
box平面中的长方形
bytea二进制数据(“字节数组”)
character varying [ (n) ]变长字符串
character [ (n) ]定长字符串
cidrIPv4 或者 IPv6 网络地址
circle平面中的圆
date日历日期(年,月,日)
double precision双精度浮点数字
inetIPv4 或者 IPv6 网络地址
integer四字节长有符号整数
interval [ § ]时间间隔
line平面中的无限长直线
lseg平面中的线段
macaddrMAC 地址
numeric [ (p, s) ]可选精度的准确数字
path平面中的几何路径
point平面中的点
polygon平面中的封闭几何路径
real单精度浮点数
smallint有符号两字节整数
serial自增四字节整数
text变长字符串
time [ § ] [ without time zone ]一天里的时间
time [ § ] with time zone一天里的时间,包括时区
timestamp [ § ] [ without time zone ]日期和时间
timestamp [ § ] with time zone日期和时间
tsquery全文检索查询
tsvector全文检索文档
txid_snapshot用户级别事务ID快照
uuid通用唯一标识符
xmlXML数据
  • 与oracle对比差异
OraclePostgreSQL
Varchar2varchar
numbernumeric
datetimestamp/date/time
不支持boolean,可通过0/1代替支持boolean
nullnull
  • 填充测试数据
create table "test".EMP
(
  empno    numeric(4) not null,
  ename    VARCHAR(10),
  job      VARCHAR(9),
  mgr      numeric(4),
  hiredate date,
  sal      numeric(7,2),
  comm     numeric(7,2),
  deptno   numeric(2)
);

insert into "test".emp (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)
values (7369, 'SMITH', 'CLERK', 7902, to_date('17-12-1980', 'dd-mm-yyyy'), 800.00, null, 20);

insert into "test".emp (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)
values (7499, 'ALLEN', 'SALESMAN', 7698, to_date('20-02-1981', 'dd-mm-yyyy'), 1600.00, 300.00, 30);

insert into "test".emp (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)
values (7521, 'WARD', 'SALESMAN', 7698, to_date('22-02-1981', 'dd-mm-yyyy'), 1250.00, 500.00, 30);

insert into "test".emp (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)
values (7566, 'JONES', 'MANAGER', 7839, to_date('02-04-1981', 'dd-mm-yyyy'), 2975.00, null, 20);

insert into "test".emp (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)
values (7654, 'MARTIN', 'SALESMAN', 7698, to_date('28-09-1981', 'dd-mm-yyyy'), 1250.00, 1400.00, 30);

insert into "test".emp (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)
values (7698, 'BLAKE', 'MANAGER', 7839, to_date('01-05-1981', 'dd-mm-yyyy'), 2850.00, null, 30);

insert into "test".emp (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)
values (7782, 'CLARK', 'MANAGER', 7839, to_date('09-06-1981', 'dd-mm-yyyy'), 2450.00, null, 10);

insert into "test".emp (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)
values (7788, 'SCOTT', 'ANALYST', 7566, to_date('19-04-1987', 'dd-mm-yyyy'), 3000.00, null, 20);

insert into "test".emp (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)
values (7839, 'KING', 'PRESIDENT', null, to_date('17-11-1981', 'dd-mm-yyyy'), 5000.00, null, 10);

insert into "test".emp (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)
values (7844, 'TURNER', 'SALESMAN', 7698, to_date('08-09-1981', 'dd-mm-yyyy'), 1500.00, 0.00, 30);

insert into "test".emp (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)
values (7876, 'ADAMS', 'CLERK', 7788, to_date('23-05-1987', 'dd-mm-yyyy'), 1100.00, null, 20);

insert into "test".emp (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)
values (7900, 'JAMES', 'CLERK', 7698, to_date('03-12-1981', 'dd-mm-yyyy'), 950.00, null, 30);

insert into "test".emp (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)
values (7902, 'FORD', 'ANALYST', 7566, to_date('03-12-1981', 'dd-mm-yyyy'), 3000.00, null, 20);

insert into "test".emp (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)
values (7934, 'MILLER', 'CLERK', 7782, to_date('23-01-1982', 'dd-mm-yyyy'), 1300.00, null, 10);

2.coalesce函数

进行空值处理,类似oracle中nvl函数

select empno, ename, coalesce(comm,0) from "test".emp

在这里插入图片描述

3.string_agg

字符串聚合,类似oracle中list_agg

Select deptno,string_agg(ename,,) fromemp group by deptno;

4.case…when…end

pg中没有decode函数只能用case…when代替,差评!

select ename, (case job when 'PRESIDENT' then '总裁' else '打工仔' end) as "职位" from "test".emp

在这里插入图片描述

5.JDBC

Oracle的jdbc连接字符串:jdbc:oracle:thin:@192.168.1.1:1521:ORCL

Postgresql的连接字符串:jdbc:postgresql:@192.168.1.1:5432/database

6.SQL语法

6.1 子查询必须要别名

在这里插入图片描述

改写后:

select * from (select * from "test".emp where deptno=20) as t

6.2 生成rownum

pg中没有rownum伪列,使用row_number()

select empno, row_number() OVER (ORDER BY empno) as "rownum" from "test".emp;

7.数字和字符串格式化

SELECT to_char(12345, '9999999999999999999')//结果'              12345',结果字符串前面有空格,位数跟格式化模式中9的位数有关;
SELECT to_char(12345, '99999')//结果'12345'
SELECT to_char(12345, '9999')//结果‘####’,当模式串小于数字个数时,字符串会显示为#,位数跟 格式化模式中9的位数有关;
SELECT to_char(12345, '')//结果''
SELECT to_number('12345', '9999999999999999999')//12345
SELECT to_number('12345', '99999')//12345
SELECT to_number(''||12345, '9999')//1234,由于模式是4位,结果忽略最后一位;
SELECT to_number('    12345', '9999999999999999999')//12345
SELECT to_number('  ab  ,1,2a3,4b5', '9999999999999999999')//12345,会忽略所有字符串中非数字字符
select to_number('12,454.8-', '99G999D9S')

或者:

–把’1234’转成整数
select cast(‘1234’ as integer) ;

select cast(‘1234’ as int) ;

8.日期时间格式化

*函数**返回类型**描述**例子*
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把字串转换成numericto_number(‘12,454.8-’, ‘99G999D9S’)
select to_timestamp('2012-05-01 23:58:59','yyyy-mm-dd hh24:mi:ss')

在这里插入图片描述

date_trunc(‘year’,now());//返回当前时间年的第一天>>>2018-01-01 00:00:00
date_trunc(‘month’,now());//返回当前月的第一天>>2018-09-01 00:00:00
date_trunc(‘day’,now()); //返回当前时间的年月日>>2018-09-14 00:00:00
date_trunc(‘second’,now()); //返回当前时间的年月日时分秒>>2018-09-14 13:30:50

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值