公司在进行数据库的重建,技术总监问我为什么不直接镜像一个业务的数据库,这样查询和分析都直接从镜像的数据库进行就行,既不占用业务数据库资源,也免去了重建数据库的投入。
答:
数据库的功能侧重点不同:
1) 对于业务数据库来说,通常用的是OLTP,是按照业务的逻辑进行考虑的,通过业务调查,逻辑分析的方式,将数据进行切分再建造数据库模型。
这里的数据库主要考虑的是存储和写入功能,并不考虑分析
- OLTP讲解:(On-Line Transaction Processing)百度百科的翻译过来叫“联机事物处理过程”,这里面的Transaction主要着重的就是事物处理,处理的事物就包含:增、删、改。
- 意思是我作为一个OLTP,更像是收银员,每一笔钱都仔仔细细收好,保证收入正确,且找零正确就行,再把收到的钱规整地分到一个个格子里,我就很完美地完成了我的任务。
- 什么是一个好的收银员,就是收的快、准 --> 因此OLTP考虑的是事物吞吐量。
转换成学术一点的话,OLTP就是要:实时性高、稳定性强、确保数据及时更新。
2) 对于分析类的数据库,通常用的都是OLAP,专门用来做数据的展示和分析的。
- OLAP讲解&#