博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
PostgreSQL使用建议
阅读量:6116 次
发布时间:2019-06-21

本文共 3732 字,大约阅读时间需要 12 分钟。

  hot3.png

一、命名规范

1. DB object: database, schema, table, view, index, function, trigger等名称

(1) 建议使用小写字母、数字、下划线的组合
(2) 建议不使用双引号即"包围,除非必须包含大写字母或空格等特殊字符
(3) 长度不能超过63个字符
(4) 禁止使用 ,例如 type, order 

2. table能包含的column数目,根据字段类型的不同,数目在 250 到 1600 之间

3. 临时或备份的DB object:table,view ,建议加上日期,table_xxx_20150826

4. index命名规则为表名_列名_idx,student_name_idx, 建议不显式给出index name,使用DBMS系统默认给出的index name, create index ON student (name);则默认给出student_name_idx

二、Column设计

1. 建议能用varchar(N) 就不用char(N),以利于节省存储空间

2. 建议能用varchar(N) 就不用text,varchar

3. 建议使用default NULL,而不用default '',以节省存储空间,

4. 建议使用ip4,ip4r,ip6,ip6r,ipaddress,iprange 来存储IP,IP范围;使用macaddr来存储MAC (Media Access Control) address

5. 建议使用timestamp with time zone(timestamptz),而不用timestamp without time zone,避免时间函数在对于不同时区的时间点返回值不同,也为业务国际化扫清障碍

6. 建议使用NUMERIC(precision, scale)来存储货币金额和其它要求精确计算的数值而不建议使用real, double precision

7. 建议使用hstore 来存储非结构化,key-value 键值型,对数不定的数据

8. 建议使用ltree 来存储 Top.中国.北京.天安门 这种树状层次结构 数据

9. 建议使用json 来存储JSON (JavaScript Object Notation) data

10. 建议使用 结合来实现地理信息数据存储及操作

11. 建议使用如下range类型代替字符串或多列来实现范围的存储

三、Constraints设计

1. 建议每个table都有主键;

2. 建议不要用有业务含义的名称作为主键,比如身份证或者国家名称,尽管其是unique

3. 建议主键的一步到位的写法:id serial primary key id bigserial primary key

四、Index设计

1. PostgreSQL 提供的index类型: B-tree, Hash, GiST (Generalized Search Tree), SP-GiST (space-partitioned GiST) and GIN (Generalized Inverted Index),目前不建议使用Hash, SP-GiST

2. 建议create 或 drop index ,加 CONCURRENTLY参数,这是个好习惯,达到与写入数据并发的效果

3. 建议对于频繁update, delete的包含于index 定义中的columntable, create index CONCURRENTLY , drop index CONCURRENTLY 的方式进行维护其对应index

4. 建议用unique index 代替unique constraints,便于后续维护

5. 建议不要建过多index,一般不要超过6个,核心table(产品,订单)可适当增加index个数

五、关于NULL

1. NULL 的判断:IS NULL IS NOT NULL

2. 注意boolean 类型取值 truefalse, NULL

3. 小心NOT IN 集合中带有NULL元素

postgres=# SELECT * FROM (VALUES(1),(2)) v(a) ;  a ---  1  2 (2 rows)  postgres=# select 1 NOT IN (1, NULL);  ?column? ----------  f (1 row)  postgres=# select 2 NOT IN (1, NULL);  ?column? ----------  (1 row) postgres=# SELECT * FROM (VALUES(1),(2)) v(a) WHERE a NOT IN (1, NULL);  a ---(0 rows)

可见,出现这种情况的根本原因在于SELECT只返回WHERE中判断条件结果为true的数据

4. 建议对字符串型NULL值处理后,进行 || 操作

postgres=# select NULL||'PostgreSQL';  ?column? ----------   (1 row) postgres=# select coalesce(NULL,'')||'PostgreSQL';   ?column? ------------  PostgreSQL (1 row)

5. 建议对hstore 类型进行处理后,进行 || 操作,避免被NULL吃掉

postgres=# select  NULL::hstore || ('key=>value') ;  ?column? ----------   (1 row) postgres=# select  coalesce(NULL::hstore, hstore(array[]::varchar[])) || ('key=>value') ;?column?---------------- "key"=>"value" (1 row) postgres=# select  coalesce(NULL::hstore,''::hstore) || ('key=>value') ;     ?column?     ----------------  "key"=>"value"  (1 row)

六、其他注意事项

1. 建议对DB object 尤其是COLUMN COMMENT,便于后续维护

2. 建议非必须时避免select *,只取所需字段,以减少网络带宽消耗,避免表结构变更对程序的影响

3. 建议update 时尽量做 <> 判断,比如update table_a set column_b = c where column_b <> c

4. 建议将单个事务的多条SQL操作,分解、拆分,或者不放在一个事务里,让每个事务的粒度尽可能小,尽量lock少的资源,避免lock dead lock的产生

5. 建议向大sizetableadd column时,将 alter table t add column col datatype not null default xxx;分解为如下,避免填充default值导致的过长时间锁表

alter table t add column col datatype ; alter table t alter column col set default xxx; update t set column = default where id = 1; .................. update t set column = default where id = N; ------此处,可以用先进的\watch来刷------即 update table t  set column= DEFAULT where id in ( select id from t where column is null limit 1000 ) ; \watch 3 alter table t alter column col set not null;

6. 建议执行DDL,比如CRAETE,DROP,ALTER 不要显式的开transaction, 因为加lockmode非常高,极易产生deadlock

7. 建议复杂的统计查询可以尝试窗口函数 

8. 建议发给PostgrSQL DBA review 及 执行的SQL,无论是使用pgadmin这种图形化工具,还是pg_dump 这种命令行工具生成的SQL,都去掉注释(--之后的部分),双引号"及alter owner等冗余或不应该带到线上生产的dev/beta DB中的信息

转载于:https://my.oschina.net/aven92/blog/497377

你可能感兴趣的文章
有趣的数学书籍
查看>>
teamviewer 卸载干净
查看>>
多线程设计模式
查看>>
解读自定义UICollectionViewLayout--感动了我自己
查看>>
SqlServer作业指定目标服务器
查看>>
UnrealEngine4.5 BluePrint初始化中遇到编译警告的解决办法
查看>>
User implements HttpSessionBindingListener
查看>>
抽象工厂方法
查看>>
ubuntu apt-get 安装 lnmp
查看>>
焊盘 往同一个方向增加 固定的长度方法 总结
查看>>
eclipse的maven、Scala环境搭建
查看>>
架构师之路(一)- 什么是软件架构
查看>>
jquery的冒泡和默认行为
查看>>
USACO 土地购买
查看>>
【原创】远景能源面试--一面
查看>>
B1010.一元多项式求导(25)
查看>>
10、程序员和编译器之间的关系
查看>>
前端学习之正则表达式
查看>>
配置 RAILS FOR JRUBY1.7.4
查看>>
AndroidStudio中导入SlidingMenu报错解决方案
查看>>