新网创想网站建设,新征程启航
为企业提供网站建设、域名注册、服务器等服务
一,脏数据:
成都创新互联是一家专业从事成都网站制作、网站设计、网页设计的品牌网络公司。如今是成都地区具影响力的网站设计公司,作为专业的成都网站建设公司,成都创新互联依托强大的技术实力、以及多年的网站运营经验,为您提供专业的成都网站建设、营销型网站建设及网站设计开发服务!
1,脏数据就是读到database buffer cache做了修改但还没有写到datafile里面的数据,只要没有写入数据文件,不管是否提交,都可以称为脏数据。
2,另外一个表的外键,由于某些原因,这个外键关联失效了,但是这个外键列没有删除,那么这一列数据也可以称为脏数据,就是没有意思的或者冗余的数据都可以叫做脏数据。
二,脏块
存放脏数据的数据块(data block)就可以称为脏块。
脏数据就是已经写入到内存里,但是还没有写入到硬盘上的数据。一般当事物没有提交的时候会产生,当事物提交以后,脏数据就会被写进硬盘的数据块,这时他就不叫脏数据了。
脏数据是相对于原数据而言的,是指被修改过的,与原数据不一样的数据。
在oracle有SGA中,有个数据高速缓冲区(database buffer cache),由许多大小相等的缓存块组成。这些块根据使用情况不同,可分为脏缓冲块、空闲缓存块和命中缓存块三类:
1. 脏缓存块(dirty buffers):它保存的是已经被修改过的数据。当一条SQL语句对某个缓存块中的数据进行修改后,这个缓存块就被标记为脏缓存块。
2. 空闲缓存块(free buffers):不包含任何数据,它们等待后台进程或服务器进程向其中写入数据。当oracle从数据文件中读取数据时,将会寻找空闲缓存块,以便将数据写入其中。
3. 命中缓存块(pinned buffers):是那些正被使用,或者被显式地声明为保留的缓存块。这些缓存块始终保留在数据高速缓冲区中,不会被换出。
dbwr 进程扫描 db buffer cache, 将其中被修改过的数据块(即脏数据)写出至磁盘.
A B 两用户,A 在10点更改X表的10到20 但一直未提交,B在10:30 要读取X表的A更改的那条记录的值,这时恰好B要读取的块在内存里面(由于A更改需要把数据读取到内存)。这时候有几种情况,假如此时ORACLE允许B读取到A更改后但未提交的数据,这时就发生了脏读。另外就是不让B读取到A的更改,读取到A更改以前的数据,这时就发生了一致性读。一致性读会从现在的脏块和undo记录 构造一个CR块 构造出来的CR块与磁盘上的块是一致的 我的理解是这样的 当然情况不只上面这一种,很多种情况 建议你看看 oracle隔离级别 相关的文章 应该会有用