当前位置: 首页 > wzjs >正文

c 如何拖控件做网站在哪里查关键词排名

c 如何拖控件做网站,在哪里查关键词排名,临清网站建设,php做动态网站建设原子事务 11.1 全有或全无效应 二级索引需要原子性的多键更新,这不仅对数据库内部一致性至关重要,也对应用数据的一致性非常有用(例如考虑账户余额和账户交易)。 我们将放弃get-set-del接口,并添加一个新的接口来允…

在这里插入图片描述

原子事务

11.1 全有或全无效应

二级索引需要原子性的多键更新,这不仅对数据库内部一致性至关重要,也对应用数据的一致性非常有用(例如考虑账户余额和账户交易)。

我们将放弃get-set-del接口,并添加一个新的接口来允许一组操作的原子执行。并发控制将在下一章讨论。

提交与回滚

我们将添加接口以标记事务的开始和结束。在结束时,更新要么生效(提交),要么由于错误或用户请求(中止)被丢弃(回滚)。

// 开始一个事务
func (kv *KV) Begin(tx *KVTX)// 结束一个事务:提交更新;发生错误则回滚
func (kv *KV) Commit(tx *KVTX) error// 结束一个事务:回滚
func (kv *KV) Abort(tx *KVTX)
写时复制实现原子性

通过写时复制(copy-on-write),无论是提交还是回滚都只是更新根指针。这已经在第6章作为错误处理实现了。

type KVTX struct {db   *KVmeta []byte // 用于回滚
}func (kv *KV) Begin(tx *KVTX) {tx.db = kvtx.meta = saveMeta(tx.db)
}func (kv *KV) Commit(tx *KVTX) error {return updateOrRevert(tx.db, tx.meta)
}func (kv *KV) Abort(tx *KVTX) {loadMeta(tx.db, tx.meta)tx.db.page.nappend = 0tx.db.page.updates = map[uint64][]byte{}
}

以前updateOrRevert()是在单个键更新后调用的。现在它被移动到了KVTX.Commit()。B+树可以根据需要多次更新,重要的是根指针。

另一种方法是通过日志实现原子性,在写时复制树中,更新由根指针捕获,而在原地更新中,则需要日志来捕获更新。

11.2 事务性接口

将树操作移到事务中

树操作现在与事务关联,因此它们被移到了KVTX中。

func (tx *KVTX) Seek(key []byte, cmp int) *BIter {return tx.db.tree.Seek(key, cmp)
}func (tx *KVTX) Update(req *UpdateReq) bool {return tx.db.tree.Update(req)
}func (tx *KVTX) Del(req *DeleteReq) bool {return tx.db.tree.Delete(req)
}

注意,这些函数不再返回错误,因为实际的磁盘更新被移到了KVTX.Commit()中。

事务表操作

对于基于表的接口,只需为KVTX添加一个包装类型。

type DBTX struct {kv KVTXdb *DB
}func (db *DB) Begin(tx *DBTX)
func (db *DB) Commit(tx *DBTX) error
func (db *DB) Abort(tx *DBTX)func (tx *DBTX) Scan(table string, req *Scanner) error
func (tx *DBTX) Set(table string, rec Record, mode int) (bool, error)
func (tx *DBTX) Delete(table string, rec Record) (bool, error)

这些操作不再处理IO错误,因此没有更新二级索引的错误处理。

11.3 可选优化

尽管我们已经建立了一个支持顺序操作的关系型数据库系统,但为了进一步挑战,还有一些优化可以考虑:

  • 减少多键更新时的复制:写时复制在一次更新中从叶节点到根节点复制节点,这对于多键更新来说不是最优的,因为中间树的节点在一个事务内分配、更新一次然后被删除。优化方法是在一个事务内只复制一次节点,并在复制的节点上使用原地更新。

  • 范围删除:虽然我们现在可以进行多键更新,但删除大量键(如删除表)仍然存在资源使用的难题。简单的做法是一次迭代并逐个删除键,但这会将整个表读入内存并在删除前反复更新节点,做了一些无用的工作。一些数据库对每个表使用单独的文件,所以这不是问题。在我们的案例中,所有内容使用单一的B+树,我们可以实现一个范围删除操作,无需查看即可释放具有特定范围的所有叶节点。

  • 压缩公共前缀:在任何排序的数据中,邻近的键可能共享一个公共前缀。在典型的关系数据库使用场景中,多列键也会导致共享前缀。因此有机会压缩节点内的键。前缀压缩使实现更加复杂(有趣),尤其是在合并和分裂时节点大小不容易预测的情况下。

代码仓库地址:database-go

http://www.dtcms.com/wzjs/490204.html

相关文章:

  • 营销方案 网站福州百度开户多少钱
  • ppt要怎么做网站品牌推广策略有哪几种
  • 卖产品怎么做网站东莞seo整站优化
  • 做推文的网站网络营销公司名字大全
  • 网站建设流程包括太原seo关键词排名优化
  • e通网网站建设企业网络营销推广
  • 上海宝山做网站公司排名常见的营销方式有哪些
  • 北京做公司网站搭建网站多少钱
  • 可以把网站建设在云主机上吗外贸网络推广服务
  • 贵阳市观山湖区建设局网站互联网十大企业
  • 网站建设制作设计seo优化湖北百度的营销推广
  • 深圳网站建设公司公司百度在线客服系统
  • 无费用开网店seo云优化外包
  • 门户网站的自身的特性怎么做网页宣传
  • 建设主题网站的顺序是什么意思百度收录官网
  • wordpress com cnseo推广方法集合
  • 昆明优化网站公司百度广告代理商查询
  • 中国建设监理官方网站seo服务合同
  • 网站app程序制作企业厦门seo网站推广优化
  • 帝国cms企业&行业协会网站模版搜索关键词推荐
  • 做企业内部管理网站要多久网络推广员要怎么做
  • 做外贸网站平台有哪些内容北京网优化seo公司
  • 建设自己网站的流程海曙seo关键词优化方案
  • 做企业网站 需要用服务器吗seo排名外包
  • 东莞求职招聘信息网seo外链友情链接
  • 广东网站设计费用seo优化专家
  • wordpress网站嵌入音乐怎么做一个网站
  • 牛商营销型网站建设方案百度免费下载
  • 如何介绍网站建设公司原创软文
  • 做flash音乐网站的开题报告长沙优化网站哪家公司好