第七章:数据持久存储与交换-shelve:对象的持久存储-写回(特定shelf类型)

7.2.2 写回
默认地,shelf不会跟踪对可变对象的修改。这说明,如果存储在shelf中的一个元素的内容有变化,那么shelf必须再次存储真个元素来显式地更新。

import shelve

with shelve.open('test_shelf.db') as s:
    print(s['key1'])
    s['key1']['new_value'] = 'this was not here before'

with shelve.open('test_shelf.db',writeback=True) as s:
    print(s['key1'])

在这个例子中,没有再次存储’key1’的相应字典,所以重新打开shelf时,修改不会保留。
运行结果:
在这里插入图片描述
对于shelf中存储的可变对象,要想自动捕获对它们的修改,可以在打开shelf时启用写回(writeback)。writevack标志会让shelf使用内存中缓存以记住从数据库获取的所有对象。shelf关闭时每个缓存对象也被写回到数据库。

import shelve
import pprint

with shelve.open('test_shelf.db',writeback=True) as s:
    print('Initial data:')
    pprint.pprint(s['key1'])

    s['key1']['new_value'] = 'This was not here before'
    print('\nModified:')
    pprint.pprint(s['key1'])

with shelve.open('test_shelf.db',writeback=True) as s:
    print('\nPreserved:')
    pprint.pprint(s['key1'])

尽管这会减少程序员犯错的机会,并且使对象持久存储更透明,但是并非所有情况都有必要使用写回模式。打开shelf时缓存会消耗额外的内存,关闭shelf时会暂停将各个缓存对象写回到数据库,这会减慢应用的速度。所有缓存的对象都要写回数据库,因为无法区分它们是否有修改。如果应用读取的数据多于写的数据,那么写回就会影响性能而没有太大意义。
运行结果:
第七章:数据持久存储与交换-shelve:对象的持久存储-写回(特定shelf类型)_第1张图片
7.2.3 特定shelf类型
之前的例子都使用了默认的shelf实现。可以使用shelve.open()而不是直接使用某个shelf实现,这是一种常见的用法,特别是使用什么类型的数据库来存储数据并不重要时。不过,有些情况下数据库格式会很重要。在这些情况下,可以直接使用DbfilenameShelf或BsdDbShelf,或者甚至可以派生shelf来得到一个定制解决方案。

你可能感兴趣的:(Python标准库)