使用PostgreSQL注意事项
一、大小写特别敏感
大写字段需要用“”引号(pg字段名使用“”,MySQL字段名使用``)
******表名以及字段名如果是小写但是为关键字,比如name,则也需使用"";
二、分页
limit ${limit} offset ${start}
三、判断条件等号前后字段类型需要一致
类型转换相关函数
https://www.runoob.com/postgresql/postgresql-functions.html
|
函数 |
返回类型 |
描述 |
实例 |
|
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 |
数字转换为字符串 |
to_char(-125.8, '999D99S') |
|
to_date(text, text) |
date |
字符串转换为日期 |
to_date('05 Dec 2000', 'DD Mon YYYY') |
|
to_number(text, text) |
numeric |
转换字符串为数字 |
to_number('12,454.8-', '99G999D9S') |
|
to_timestamp(text, text) |
timestamp |
转换为指定的时间格式 time zone convert string to time stamp |
to_timestamp('05 Dec 2000', 'DD Mon YYYY') |
|
to_timestamp(double precision) |
timestamp |
把UNIX纪元转换成时间戳 |
to_timestamp(1284352323) |
四、日期格式转换(格式跟oracle类似)
eg:
时间转字符串:to_char(now(),'yyyy-mm-dd hh24:mi:ss');
字符串转数字:to_number(tenant_id,'99999');
|
占位符 |
描述 |
|
HH |
一天的小时数(01-12) |
|
HH12 |
一天的小时数(01-12) |
|
HH24 |
一天的小时数(00-23) |
|
MI |
分钟(00-59) |
|
SS |
秒(00-59) |
|
MS |
毫秒(000-999) |
|
US |
微秒(000000-999999) |
|
AM |
正午标识(大写) |
|
Y,YYY |
带逗号的年(4和更多位) |
|
YYYY |
年(4和更多位) |
|
YYY |
年的后三位 |
|
YY |
年的后两位 |
|
Y |
年的最后一位 |
|
MONTH |
全长大写月份名(空白填充为9字符) |
|
Month |
全长混合大小写月份名(空白填充为9字符) |
|
month |
全长小写月份名(空白填充为9字符) |
|
MON |
大写缩写月份名(3字符) |
|
Mon |
缩写混合大小写月份名(3字符) |
|
mon |
小写缩写月份名(3字符) |
|
MM |
月份号(01-12) |
|
DAY |
全长大写日期名(空白填充为9字符) |
|
Day |
全长混合大小写日期名(空白填充为9字符) |
|
day |
全长小写日期名(空白填充为9字符) |
|
DY |
缩写大写日期名(3字符) |
|
Dy |
缩写混合大小写日期名(3字符)dy缩写小写日期名(3字符) |
|
DDD |
一年里的日子(001-366) |
|
DD |
一个月里的日子(01-31) |
|
D |
一周里的日子(1-7;周日是1) |
|
W |
一个月里的周数(1-5)(第一周从该月第一天开始) |
|
WW |
一年里的周数(1-53)(第一周从该年的第一天开始) |
转时间格式
to_date( #{req_tm},'yyyy-mm-dd')
select now()::varchar(19);
select cast( '2018-03-22 06:15:16'as timestamp)
|
函数 |
返回类型 |
描述 |
例子 |
|
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') |
五、实现MySQL中的GROUP_CONCAT()方法
使用:array_to_string(GROUP_CONCAT(DISTINCT cgu.group_id),',')
创建自定义聚合函数
CREATE AGGREGATE group_concat(anyelement)
(
sfunc = array_append, -- 每行的操作函数,将本行append到数组里
stype = anyarray, -- 聚集后返回数组类型
initcond = '{}' -- 初始化空数组
);
六、null替换
coalesce(pmodule_id,'')
七、模糊查询
SELECT * FROM public."user"
WHERE UPPER(username) LIKE UPPER('%' || #{username} || '%');
SELECT * FROM public."user"
WHERE CONCAT(username) LIKE CONCAT('%', #{username}, '%');
SELECT * FROM public."user"
WHERE username LIKE '%' || #{username} || '%';
八、实现MySQL中的主键自增功能
为字段添加自增功能时需要创建序列
--创建序列字段自增
CREATE SEQUENCE imp_item_status_map_seq --序列名
START WITH 200 --起始值
INCREMENT BY 1 --增量
NO MINVALUE
NO MAXVALUE
CACHE 1;
--删除序列
DROP SEQUENCE imp_item_status_map_seq cascade;
--将表中字段关联序列
--mapping_id 需要关联表中的字段
alter table imp_item_status_map alter column mapping_id set default nextval('imp_item_status_map_seq');
九、
--创建类似UUID()函数方法
create or replace function random_string(integer)
returns text as
$body$
select array_to_string(array(select substring('0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz' FROM (ceil(random()*62))::int FOR 1) FROM generate_series(1, $1)), '');
$body$
language sql volatile;
使用PostgreSQL注意事项的更多相关文章
- Gogs官方帮助文档
环境要求 数据库(选择以下一项): MySQL:版本 >= 5.7 PostgreSQL MSSQL TiDB(实验性支持,使用 MySQL 协议连接) 或者 什么都不安装 直接使用 SQLit ...
- postgresql Streaming Replication监控与注意事项
一监控Streaming Replication集群 1 pg_stat_replication视图(主库端执行) pid Wal sender process的进程ID usesysid 执行流复制 ...
- Entity Framework 6连接Postgresql、SQLite、LocalDB的注意事项和配置文件
Postgresql Postgresql支持Code First的方式自动生成表,不过默认的模式是dbo而不是public,而且还可以自动生成自增主键. <?xml version=" ...
- postgresql文档生成注意事项
如果要生成中文版的postgresql,目前我所知道的方法见我的一篇博客http://www.cnblogs.com/codeblock/p/4812445.html 里面有详细的介绍,但是生成的文档 ...
- 【数据库】postgresql数据库创建自增序列id的注意事项
1.创建一张表 CREATE TABLE "public"."tt" ( "name" varchar(128), "status ...
- 将数据从MySQL迁移到Oracle的注意事项
将数据从MySQL迁移到Oracle的注意事项1.自动增长的数据类型处理MYSQL有自动增长的数据类型,插入记录时不用操作此字段,会自动获得数据值.ORACLE没有自动增长的数据类型,需要建立一个自动 ...
- Shp数据批量导入Postgresql工具的原理和设计
文章版权由作者李晓晖和博客园共有,若转载请于明显处标明出处:http://www.cnblogs.com/naaoveGIS/. 1.背景 在制作整体的开源工具箱产品中,数据入库是一个重要的环节.虽然 ...
- SQL Server 导出数据到 PostgreSQL
乘着倒数据这会儿,把方法记录一下 需求:因为数据迁移,需要将SQL Server 2012中的数据库导入到PostgreSQL 数据库中 思路:创建一个空的数据库,便于导入数据.下载PostgreSQ ...
- postgresql copy命令介绍
COPY 命令可以快速的导入数据到postgresql数据库中,文件格式类似TXT.CVS之类.适合批量导入数据,速度比较快.注意COPY只能用于表,不能用于视图. COPY 命令里面的文件必须是由服 ...
随机推荐
- 基于FPGA的RGB图像转灰度图像算法实现
一.前言 最近学习牟新刚编著<基于FPGA的数字图像处理原理及应用>的第六章直方图操作,由于需要将捕获的图像转换为灰度图像,因此在之前代码的基础上加入了RGB图像转灰度图像的算法实现. 2 ...
- 【i3】manjaro配置
介绍 这是一期关于manjaro的安装到开发环境配置i3wm的教程.我即将在manjaro_gnome里面演示 主要的软件或者工具 i3wm tmux nvim polybar compton ran ...
- C++走向远洋——30(六周,项目一1.0)
*/ * Copyright (c) 2016,烟台大学计算机与控制工程学院 * All rights reserved. * 文件名:fenshu.cpp * 作者:常轩 * 微信公众号:World ...
- 微信小程序采坑之scroll-view
当设置了scroll-y为true之后,纵向是没有问题的,会出现滚动条. Android上一切都是那么的祥和, ios上你会发现如果你scroll-view里面的东西超过横向的宽度时,就会隐藏了. 也 ...
- qt creator源码全方面分析(3-1)
目录 qtcreator.pro 包含qtcreator.pri include(filename) Qt版本判断 message(string) $$运算符 error(string) 包含doc. ...
- swagger使用以及一些注解说明
@Api:作用于Conntroller类上 value:字段说明 description:描述 tags:分组 (经常用到tags,例如如下,我只是给value,则默认应用了类名) @ApiOpera ...
- Matplotlib数据可视化(4):折线图与散点图
In [1]: from matplotlib import pyplot as plt import numpy as np import matplotlib as mpl mpl.rcParam ...
- 初识 “HTML”
HTML 什么是HTML? ①全称:超文本标记语言②超文本:在普通的文本内容的基础上添加超链接.图片.视频等③标记语言:HTML提供一系列标签④版本:HTML 4.01 HTML声明 1.编码格式:H ...
- 《第31天:JQuery - 轮播图》
源码下载地址:链接:https://pan.baidu.com/s/16K9I... 提取码:0ua2 写这篇文章,当做是对自已这一天的一个总结.写轮播图要准备的东西:三张尺寸大小一样的图片.分为三个 ...
- 前端每日实战:147# 视频演示如何用纯 CSS 创作透视按钮的悬停特效
效果预览 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/qJEdKb 可交互视频 此视频是可 ...