PostgreSQL源码学习–删除数据#1,2「建议收藏」

PostgreSQL源码学习–删除数据#1,2「建议收藏」本节介绍heapam_tuple_delete和table_tuple_delete函数。 heapam_tuple_delete函数 //src/backend/access/heap/heapa…

PostgreSQL源码学习--删除数据#1,2

本节介绍heapam_tuple_delete和table_tuple_delete函数。

heapam_tuple_delete函数

//src/backend/access/heap/heapam_handler.c

static TM_Result
heapam_tuple_delete(Relation relation, ItemPointer tid, CommandId cid,
				Snapshot snapshot, Snapshot crosscheck, bool wait,
				TM_FailureData *tmfd, bool changingPart)
{
	/* 目前,索引元组的删除是在vacuum时处理的 */
	return heap_delete(relation, tid, cid, crosscheck, wait, tmfd, changingPart);
}

代码100分

table_tuple_delete函数

代码100分//src/backend/access/heap/heapam_handler.c

static inline TM_Result
table_tuple_delete(Relation rel, ItemPointer tid, CommandId cid,
			   Snapshot snapshot, Snapshot crosscheck, bool wait,
			   TM_FailureData *tmfd, bool changingPart)
{
	/* 默认的表存储引擎的话,rd_tableam赋值为heapam_methods,
	   其tuple_delete指向的就是heapam_tuple_delete函数 */
	return rel->rd_tableam->tuple_delete(rel, tid, cid,
						 snapshot, crosscheck,
						 wait, tmfd, changingPart);
}

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
转载请注明出处: https://daima100.com/8006.html

(0)
上一篇 2023-03-09
下一篇 2023-03-09

相关推荐

  • SQL-索引[通俗易懂]

    SQL-索引[通俗易懂]理解“聚集索引”和“非聚集索引” ① 聚集索引(clustered index,也称聚类索引、簇集索引):把内容本身就是一种按照一定规则排列的目录称为“聚集索引” 我们的汉语字典的正文本身就是一个聚集

    2023-04-22
    162
  • spring事务与数据库事务[亲测有效]

    spring事务与数据库事务[亲测有效]一、事务与数据库的隔离级别 1、事务的ACID属性 A(Atomicity):原子性,事务要么都成功,要么都失败,是一个整体 C(Consistency):一致性,事务前后数据保持一致,如张三去银行…

    2023-02-25
    145
  • 翻译 | Kubernetes 将改变数据库的管理方式

    翻译 | Kubernetes 将改变数据库的管理方式作者:Álvaro Hernández 当技术决策人考虑在 Kubernetes 上部署数据库时,面临的第一个问题就是:“Kubernetes 有应对有状态服务的能力吗?”多年来的

    2023-05-09
    137
  • Python Wallclock Time:测量程序中代码执行的实际时间

    Python Wallclock Time:测量程序中代码执行的实际时间bWallclock time/b(也称为Wall time)是指从程序开始运行到程序结束的实际时间,它包括了CPU执行时间以及其他因素(如I/O操作和等待时间)所消耗的时间。在Python中,我们可以使用多种方式来测量代码执行的Wall time,以此来评估程序的性能和效率。本文将介绍Python中测量Wall time的方法,以及如何使用它们来优化代码。

    2023-12-31
    117
  • redis主从复制什么时候复制

    redis主从复制什么时候复制当master服务器与slave服务器正常连接时,master服务器会发送数据命令流给slave服务器,将自身数据的改变复制到slave服务器。

    2022-12-20
    141
  • 第三天MYSQL

    第三天MYSQL第三天MySQL学习 :分组函数、分组查询、连接查询(等值连接、非等值连接、自连接)

    2023-02-25
    139
  • ORA-00845 startup启动不起来关于磁盘空间扩充

    ORA-00845 startup启动不起来关于磁盘空间扩充问题描述:今天在虚拟机下进行startup的操作,但是没有起来,系统报错:ORA-00845: MEMORY_TARGET not supported on this system 1.startup

    2022-12-23
    148
  • day09-2视图和用户权限[亲测有效]

    day09-2视图和用户权限[亲测有效]视图和用户权限 1.视图(view) 看一个需求 emp表的列信息很多,有些信息是个人重要信息(比如:sal、comm、mgr、hiredate),如果我们希望某个用户只能查询emp表的empno、e

    2023-06-09
    178

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注