基于DB的编程
现在我们大多数的开发都是基于数据库,虽然数据库为我们提供了事务机制,保证存储的数据的ACID,但是,当我们在完成一个业务操作时,涉及到对数据库的大量操作,如果把这些操作在一个事务中,肯定是安全的,但是这样的话其他的操作可能无法继续,性能获取下降。此时我们可以将事务尽可能的短,部分不涉及对后续操作有影响的我们可以采取程序控制,而不是完全借助数据库事务机制来完成。
少量使用大事务。
=====================================================================================================
多个系统使用一个DB:
DB挂接多个系统:一些系统主要采集数据,一些系统主要查询数据(或者抓取数据到自己的系统)
系统的DAO层就是构建SQL(按照业务构建SQL)
left join---从小到大进行连接(大类别到小类别)
inner join
case when --汇总或者查询
where
group by
order by
case when 类似于where 二次过滤(行转列)
最后构建满足页面需求的报表格式数据(业务数据+辅助数据(动态表头等))
=====================================================================================================
批量插入:
insert into select *
或者
batch批量执行SQL语句
=====================================================================================================
数据库里面的数据:
辅助数据(元数据):---主要就是管理数据,一般变化少
业务数据:采集的数据 (要对这些数据进行分析)--通过外键进行组织,最后形成一张表连接关系(先后关系,也体现出业务处理产生的数据的先后顺序)
编程:
存储过程的编程:编程主要就是存储临时变量,这是就会使用变量进行存储,此时会使用临时表,待存储过程执行完毕之后,临时数据就可以删除,所以存储过程里面一般 都会存在临时表进行存储数据(创建临时表,插入临时数据到临时表,转存临时表数据到业务表,删除临时表),此时就涉及到存储过程编程的一个流程处理过程。
=====================================================================================================
为什么现在数据库都讲解集群这些技术。
下面说说自己的理解,不管是什么技术,显示世界的工作都是人工进行操作,慢慢的出现了自动化的处理过程,用计算机进行模拟现实世界的工作,这样首先就是一些硬件,比如存储设备,就是对业务数据的存储,但是随着数量的越来越多,存储容量也越来越大,但是一个毕竟多不了多少,所有出现了多个存储设备进行存储。但是怎么存储,这样又有专门的存储软件,比如数据库软件,所以他可以吧数据进行存储到存储到设备里面,但是一个数据库软件要有好多的链接的话,这样这些链接也需要占用内存的容量,所以必须使用多个数据库软件操作存储设备,这样一来并发量也就比较好,但是这样一来一个业务数据通过多个数据库实例操作分布在不从的存储设备上(为什么那?因为IO是有限制的,所以多存储来并发这些问题),这样数据库并发压力就会减少,但是如何减少,这样的话就需要进行数据库请求的负载均衡技术,数据库的压力解决的方案还有一些中间件进行解决。
基于DB的编程的更多相关文章
- C++服务器开发之基于对象的编程风格
Thread.h #ifndef _THREAD_H_ #define _THREAD_H_ #include <pthread.h> #include <boost/functio ...
- 通过JavaScript原型链理解基于原型的编程
零.此文动机 用了一段时间的Lua,用惯了Java C++等有Class关键字的语言,一直对Lua的中的面向对象技术感到费解,一个开源的objectlua更是看了n遍也没理解其中的原理,直到看到了Pr ...
- Unity基于响应式编程(Reactive programming)入门
系列目录 [Unity3D基础]让物体动起来①--基于UGUI的鼠标点击移动 [Unity3D基础]让物体动起来②--UGUI鼠标点击逐帧移动 时光煮雨 Unity3D让物体动起来③—UGUI DoT ...
- vc 基于对话框多线程编程实例——线程之间的通信
vc基于对话框多线程编程实例——线程之间的通信 实例:
- 基于Socket网络编程
版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/a2011480169/article/details/73602708 博客核心内容: 1.Sock ...
- 异常处理、socke基于TCP协议编程
一.异常处理 1.错误和异常 1.程序中难免出现错误,而错误分成两种 (1)语法错误(这种错误过不了Python解释器的语法检测,必须在程序执行前改正) #语法错误示范一 if #语法错误示范二 de ...
- AutoSharedLibrary -- 基于模板元编程技术的跨平台C++动态链接载入库
基于模板元编程技术的跨平台C++动态链接载入库.通过模板技术,使用者仅需通过简单的宏,就可以使编译器在编译期自己主动生成载入动态链接库导出符号的代码,无不论什么额外的执行时开销. extern &qu ...
- spring之AspectJ基于xml AOP编程
一.引言: AspectJ框架不仅实现了面向切面编程,而且还支持注解,spring将它引入自己的规范之中. 二.需要了解: AspectJ是基于java语言的AOP框架 spring2.0之后支持As ...
- 基于任务的编程模型TAP
一.引言 在上两个专题中我为大家介绍.NET 1.0中的APM和.NET 2.0中的EAP,在使用前面两种模式进行异步编程的时候,大家多多少少肯定会感觉到实现起来比较麻烦, 首先我个人觉得,当使用AP ...
随机推荐
- javaScript 真经 小感 this 指向
编程世界只存在两种基本元素:一个是数据.一个是代码. (能写代码算入门,能处理复杂场景或者数据算合格,能不变应万变是不朽) 最流行的编程思想莫过于面向对象编程,因为面向对象编程思想把数据和代码结合成统 ...
- Flutter的需要与原生交互的一些常用库
[说明]由于这些库一直在更新,请自己选择合适的稳定版本下载. 另外如果发现有问题或者你有更好的库,欢迎留言告诉我. 谷歌官方的针对Dart语言的一些实用性的功能以及扩展的库 -- Quiver Qui ...
- git入门篇
git是一个分布式版本管理软件,总之是一个软件. github是一个代码托管平台,总之是一个网站. github这个网站使用git这个版本管理软件来托管代码. 相当于本地.公司服务器.Github网站 ...
- Coderforce 560B-Gerald is into Art
题目大意:给了三个矩形的长和宽,问第一个能否把其他两个装在内部,要求内部之间不重叠,不出界(可重边)? 题目分析:这道题...考虑不够全面导致比赛时没有出来...当时,就是觉得自己的代码很完美,不可能 ...
- 处理XML Publisher导出EXCEL值变为科学计数法的问题
<fo:bidi-override direction="ltr" unicode-bidi="bidi-override"><?PoOrde ...
- Spring Boot 整合Swagger2构建API文档
1.pom.xml中引入依赖 <dependency> <groupId>io.springfox</groupId> <artifactId>spri ...
- 002PHP文件处理——文件处理 is_dir mkdir getcwd chdir rmdir
<?php /** * 66 文件处理 is_dir mkdir getcwd chdir rmdir */ //is_dir() 判断一个目录是否存在 //var_dump(is_dir('6 ...
- iOS笔记之ScrollView
ScrollView三个基本的要理解的属性: contentSize The size of the content view.所以很好理解,contentSize也就是scrollView可滚动的区 ...
- Java例子
1. 本章学习总结 今天主要学习了三个知识点 封装 继承 多态 2. 书面作业 Q1. java HelloWorld命令中,HelloWorld这个参数是什么含义? 今天学了一个重要的命令javac ...
- 201621123006 《Java程序设计》第13周学习总结
1. 本周学习总结 以你喜欢的方式(思维导图.OneNote或其他)归纳总结多网络相关内容. 2. 为你的系统增加网络功能(购物车.图书馆管理.斗地主等)-分组完成 为了让你的系统可以被多个用户通过网 ...