本文翻译自Coding-Geek文章:< How does a relational database work>. 原文链接:http://coding-geek.com/how-databases-work/#Buffer-Replacement_strategies 紧接上一篇文章,本文翻译了如下章节: 一. Log manager(日志管理) 通过前面的章节,我们已经知道,为了提升性能,数据库会将数据缓存在内存中.但是,如果在事务提交过程中,数据库服务器崩溃了.缓存在内存的数据就会丢失…
本文翻译自Coding-Geek文章:< How does a relational database work>. 原文链接:http://coding-geek.com/how-databases-work/#Buffer-Replacement_strategies 紧接上一篇文章,本文翻译了如下章节: Transaction manager(事务管理器) 一.关于ACID 一个满足ACID标准的事务,符合以下四个条件: Atomicity(原子性): 一个事务要么完整的执行所有对数据库…
本文翻译自Coding-Geek文章:< How does a relational database work>.原文链接:http://coding-geek.com/how-databases-work/#Buffer-Replacement_strategies 本文翻译了如下章节, 介绍数据库的查询优化器索引: Indexes–索引 我们已在介绍B+树的章节讲过索引(译者:此章不再细讲).仅需要记住的一点是索引已经排好序了. 当然,还有其它类型的索引,例如bitmap indexes…
本文翻译自Coding-Geek文章:< How does a relational database work>.原文链接:http://coding-geek.com/how-databases-work/#Buffer-Replacement_strategies 本文翻译了如下章节, 介绍数据库的统计分析: Statistics–数据特征统计分析 在了解数据库如何做查询优化前,我们先讲一下数据库如何做数据特征分析.没有数据特征分析的数据库不是优秀的数据库. 如果你不指令数据库分析数据,…
本文翻译自Coding-Geek文章:< How does a relational database work>. 原文链接:http://coding-geek.com/how-databases-work/#Buffer-Replacement_strategies 本文翻译了如下章节: 一.Merge Sort – 归并排序 当你需要对集合排序时,你怎么做? 什么? 你直接调用Sort()函数,-好,这是一个不错的方案.但是,对于数据库,你必须理解Sort()函数内部是如何工作的. 有…
本文翻译自Coding-Geek文章:< How does a relational database work>. 原文链接:http://coding-geek.com/how-databases-work/#Buffer-Replacement_strategies 本文翻译了如下章节: 一. 前言 谈到关系型数据库,我想不到有什么东西能缺少它,可以说关系型数据已经无处不在.存在各种不同的关系型数据库:从轻量有用的SQLite到功能强悍的数据仓库. 但是,这只是一篇介绍关系型数据库工作原…
本文翻译自Coding-Geek文章:< How does a relational database work>. 原文链接:http://coding-geek.com/how-databases-work/#Buffer-Replacement_strategies 先翻译高速缓存章节,后续有时间再翻译其它章节.翻译内容在原文的目录: 一.数据管理器 数据查询器执行查询操作,从数据表中获取数据,它向Data Manger发送请求,获取数据.其中存在2个问题: 关系型数据使用事物模型,当数…
本文翻译自Coding-Geek文章:< How does a relational database work>. 原文链接:http://coding-geek.com/how-databases-work/#Buffer-Replacement_strategies 先翻译快速缓存章节.兴许有时间再翻译其他章节. 翻译内容在原文的文件夹: 一.数据管理器 数据查询器运行查询操作,从数据表中获取数据.它向Data Manger发送请求,获取数据.当中存在2个问题: 关系型数据使用事物模型.…
本文翻译自Coding-Geek文章:< How does a relational database work>.原文链接:http://coding-geek.com/how-databases-work/#Buffer-Replacement_strategies 本文翻译了如下章节, 介绍数据库整体框架: Global overview 所谓的数据库是指一组易于访问和修改的数据集合.但是,但是一组简单的文件也能实现这个功能.实际上,最近简单的一些数据库系统如SQLLite实现的功能与一…
本文翻译自Coding-Geek文章:< How does a relational database work>.原文链接:http://coding-geek.com/how-databases-work/#Buffer-Replacement_strategies 本文翻译了如下章节, 介绍数据库的客户端管理器组件: Client manager 客户端管理器是一个处理与数据库客户端连接通信的组件.数据库的客户端可以是Web服务器,也可以是终端应用程序.数据库提供了各种访问数据库的接口,…
本文翻译自Coding-Geek文章:< How does a relational database work>. 原文链接:http://coding-geek.com/how-databases-work/#Buffer-Replacement_strategies 本文翻译了如下章节: 一.Array.Tree and Hash table 通过前面的章节, 我们已经理解了时间复杂和归并排序的概念,接下来我要介绍三种数据结构.这三种数据结构非常重要,它们是现代数据库系统的基石.我也会讲…
本文翻译自Coding-Geek文章:< How does a relational database work>.原文链接:http://coding-geek.com/how-databases-work/#Buffer-Replacement_strategies 本文翻译了如下章节, 介绍数据库的查询优化器: Query optimizer–查询优化器 当前所有流行的数据库都使用基于成本的算法(CBO)优化查询SQL.其思路是为所有的操作指令赋予一个成本值,然后找出能降低成本的最优指令…
本文翻译自Coding-Geek文章:< How does a relational database work>.原文链接:http://coding-geek.com/how-databases-work/#Buffer-Replacement_strategies 本文翻译了如下章节, 介绍数据库的客户端管理器组件: Query manager-数据库查询器 本章描述的查询器是数据库强大能力的核心所在.通过查询器,所有的查询SQL语句将被转换为能快速执行的代码.代码执行后,执行结果将返回…
本文翻译自Coding-Geek文章:< How does a relational database work>.原文链接:http://coding-geek.com/how-databases-work/#Buffer-Replacement_strategies 本文翻译了如下章节, 介绍数据库查询优化器的数据访问方式: Access Path–数据访问方法 在执行联表操作之前先要获取数据.现在讲一下获取数据有哪些方式. Note:由于所有获取数据方式的关键都是磁盘I/O,所以我不会在…
本文翻译自Coding-Geek文章:< How does a relational database work>.原文链接:http://coding-geek.com/how-databases-work/#Buffer-Replacement_strategies 本文翻译了如下章节, 介绍数据库的SQL重写器组件: Query rewriter -查询重写器 在这个处理环节,开发人员写的SQL语句会被转换为一种DBMS内部的表示方式.重写SQL有三个目的: 对SQL语句做提前优化(译者…
本文翻译自Coding-Geek文章:< How does a relational database work>.原文链接:http://coding-geek.com/how-databases-work/#Buffer-Replacement_strategies      本本文翻译了如下章节, 介绍数据库的SQL解析器组件: Query parser–SQL解析器 每条SQL语句都会被送到解析器中检查SQL语句的合法性.如果你的SQL写得有问题,解析器将拒绝执行.例如,将"…
本文讲解使用Spring-Data-Jpa操作数据库. JPA定义了一系列对象持久化的标准. 一.在项目中使用Spring-Data-Jpa 1. 配置文件application.properties中配置如下代码: spring: datasource: driver-class-name: com.mysql.jdbc.Driver url: jdbc:mysql://127.0.0.1:3306/dbstudent username: root password: ccvdp jpa: h…
Linux系统Cache 管理是 Linux 内核中一个很重要并且较难理解的组成部分.本文详细介绍了 Linux 内核中文件 Cache 管理的各个方面,希望能够帮助到你. 操作系统和文件 Cache 管理1 操作系统是计算机上最重要的系统软件,它负责管理各种物理资源,并向应用程序提供各种抽象接口以便其使用这些物理资源.从应用程序的角度看,操作系统提供了一个统一的虚拟机,在该虚拟机中没有各种机器的具体细节,只有进程.文件.地址空间以及进程间通信等逻辑概念.这种抽象虚拟机使得应用程序的开发变得相对…
概述 SQL标准定义了4类隔离级别,包括了一些具体规则,用来限定事务内外的哪些改变是可见的,哪些是不可见的.低级别的隔离级一般支持更高的并发处理,并拥有更低的系统开销. 1. Read Uncommitted(读取未提交内容) 在该隔离级别,所有事务都可以看到其他未提交事务的执行结果.本隔离级别很少用于实际应用,因为它的性能也不比其他级别好多少.读取未提交的数据,也被称之为脏读(Dirty Read). 2. Read Committed(读取提交内容) 这是大多数数据库系统的默认隔离级别(但不…
在上一篇文章"一个非侵入的Go事务管理库--如何使用"中,我讲述了如何使用事务库.有些读者可能读过"清晰架构(Clean Architecture)的Go微服务: 事物管理" ,其中描述了事务管理系统的旧版本.那篇文章和本文之间会有一些重叠.因为大多数人可能还没有读过那篇文章或者即使读了也忘记了它的内容.因此为了照顾多数读者,本文还是从头开始(假设你没有读过前文).如果你读过,那你可以直接跳过熟悉的部分. 好的事务库对于使用它的应用程序是透明的.在Go的"…
Spring提供了一致的事务管理抽象.这个抽象是Spring最重要的抽象之一, 它有如下的优点: 为不同的事务API提供一致的编程模型,如JTA.JDBC.Hibernate和MyBatis数据库层 等: 提供比大多数事务API更简单的,易于使用的编程式事务管理API: 完美整合Spring数据访问抽象: 支持Spring声明式事务管理: 这篇博客就来介绍Spring事务管理相关的内容. 事务简介 什么是事务 事务(Transaction)一般是指对数据库的一个或一组操作单元. 事务的作用 1.…
关系型数据库ACID 一.事务 定义:所谓事务,它是一个操作序列,这些操作要么都执行,要么都不执行,它是一个不可分割的工作单位. 准备工作:为了说明事务的ACID原理,我们使用银行账户及资金管理的案例(ATM)进行分析. // 创建数据库 create table account( idint primary key not null, namevarchar(40), moneydouble ); // 有两个人开户并存钱 insert into account values(1,'A',10…
说明:未整理版,未完待续,请绕行 本部分的重点是数据访问以及数据访问层与业务层之间的交互. 1.Spring框架的事务管理 介绍 http://docs.spring.io/spring/docs/current/spring-framework-reference/html/transaction.html 为什么要使用Spring事务管理?最有竞争力的原因是综合的事务支持! Spring框架提供了一致的事务管理抽象,能够带来如下好处: 不同事务APIs, 相同的编程模型.不同的事务APIs:…
一直对非关系型数据库和关系型数据库的了解感觉不太深入,在网上收集了一些关于sql和nosql的区别和优缺点分享给大家. Nosql介绍 Nosql的全称是Not Only Sql,这个概念早起就有人提出,在09年的时候比较火.Nosql指的是非关系型数据库,而我们常用的都是关系型数据库.就像我们常用的mysql,sqlserver一样,这些数据库一般用来存储重要信息,应对普通的业务是没有问题的.但是,随着互联网的高速发展,传统的关系型数据库在应付超大规模,超大流量以及高并发的时候力不从心.而就在…
一.关系型数据库 关系型数据库,是指采用了关系模型来组织数据的数据库.    关系模型是在1970年由IBM的研究员E.F.Codd博士首先提出的,在之后的几十年中,关系模型的概念得到了充分的发展并逐渐成为主流数据库结构的主流模型.    简单来说,关系模型指的就是二维表格模型,而一个关系型数据库就是由二维表及其之间的联系所组成的一个数据组织.关系模型中常用的概念:    关系:可以理解为一张二维表,每个关系都具有一个关系名,就是通常说的表名    元组:可以理解为二维表中的一行,在数据库中经常…
1.MySQL中的索引 在MySQL,索引是由B+树实现的,B+是一种与B树十分类似的数据结构. 形如下面这种: 其结构特点: (1)有n课子树的结点中含有n个关键码. (2)非根节点子节点数: ceil(m/2)<= k <= m(ceil是天花板函数的意思,也就是向上取整,比如ceil(1.2)=2 ),m为该B+树的阶数.根节点最少有两个子节点,最多同样为m个. (2)叶子节点包含了全部关键码的信息,及指向含有这些关键码记录的指针.并且叶子节点根据关键码的大小自小至大的顺序链接,叶子节点…
本文是我翻译自国外技术博客的一篇文章,其中讲述了 UEFI 的一些基本概念和细节. 本文的原始链接位于: https://www.happyassassin.net/2014/01/25/uefi-boot-how-does-that-actually-work-then/ 本人的翻译水平有限,难免多有疏漏.废话不多说,请看正文: 又到 AdamW 的讲课时间了,如果你不想听我的长篇大论,那么请出门右拐. Kamil Paral 说我有 写作癖 ,知道自己的坏习惯也是件好事. 可能你已经在互联网…
参阅:<innodb存储引擎内幕>原创文章,会不定时更新,转发请标明出处:http://www.cnblogs.com/janehoo/p/7717041.html 一.概述: innodb的整个体系架构就是由多个内存块组成的缓冲池及多个后台线程构成.缓冲池缓存磁盘数据(解决cpu速度和磁盘速度的严重不匹配问题),后台进程保证缓存池和磁盘数据的一致性(读取.刷新),并保证数据异常宕机时能恢复到正常状态. 缓冲池主要分为三个部分:redo log buffer.innodb_buffer_poo…
有关事务的楔子 什么是事务??? 事务就是以可控的方式对数据资源进行访问的一组操作. 事务本身持有四个限定属性 原子性,一致性,隔离性,持久性 事务家族 Resource Manager  RM,负责存储并管理系统数据资源的状态.数据库服务器.JMS消息服务器等都是. Transaction Processing Monitor. TPM或者 TP Monitor, 分布式事务场景中协调多个RM的事务处理. Transaction Manager.TM 是TP Monitor的核心模块,直接负责…
Tomcat 系统架构与设计模式,第 1 部分: 工作原理 这个分为两个部分的系列文章将研究 Apache Tomcat 的系统架构以及其运用的很多经典设计模式.本文是第 1 部分,将主要从 Tomcat 如何分发请求.如何处理多用户同时请求,还有它的多级容器是如何协调工作的角度来分析 Tomcat 的工作原理,这也是一个 Web 服务器首要解决的关键问题. 41 评论: 许 令波, Java 开发工程师, 淘宝网 关闭 [x] 许令波,现就职于淘宝网,是一名 Java 开发工程师.对大型互联网…