数据库最近学到的小知识(一

由于大部分内容都是再网上看的,可能会存在一些不正确的地方

对于线上业务的一些数据是选择物理删除还是逻辑删除?

由于最近在收集看一些数据库的东西,恰好昨晚听直播UP主说了这个问题部分内容可能记不太清了。

直接删除

  • 1.直接一个观点可能是会省一些存储空间,直接删除会释放些空间
  • 2.本来就是无用的数据放在那里占地方,还影响查询速度

逻辑删除

  • 1.数据可能后面会有些用,用到的时候可以再恢复
  • 2.有问题的数据的变更记录再库里面保存着可以用于历史追踪
  • 3.本来delete系统也走的是逻辑删除

观点大概分两类,但是和今天讨论的内容有哪些关系?

今天说的就是deleted删除的内容

  • 1.问:数据库中的删除操作实际是怎么进行的?
  • 答:数据库中的数据删除是逻辑删除的(PG的库中可以直接查xmin,xmax,cmin,cmax,txid_current()。其中xmin是数据被写入的时候写入的系统事务编号,xmax是数据再被修改或者删除的时候写的的事务编号,当xmax位置有值的时候意味这这条数据是被删除的)。
  • 2.问:系统存储的碎片化怎么来的
  • 答:根据上面的说法,就是有删除不是直接抹除的而是进行打标记,慢慢积累就碎片化严重了。

还有个问题就是更新也有点困扰

举个例子 某个字段VARCAHR2(50) 当前的数据是 Hello,想修改为Hello,World!。也想修改为Hi。

  • 问题的来源:磁盘上的数据是按照顺序写入的(内存的话我们不必关心数据指向的位置我们只需要设计结构就可以了,但是存储的数据我们却要考虑这个问题因为我们要把数据反向映射为我们需要的结构),也就是一个萝卜一个坑每条数据相邻的上面和下面都是有数据的。
  • 修改方式1.存的时候有些预留空间直接修改。但是这样有个问题就是空间利用率不高。
  • 修改方式2.修改的时候如果修改的这个新值的长度小于等于原有的我就直接再原有基础上进行处理。但是这里也有个问题如果字符数据小的话磁盘上相邻的下个数据的读取问题。
  • 修改方式3.原有的数据打删除标记,然后再新添加一条数据。这里有个问题就是利用率的问题,需要文件有整理的工具,还可以再新增数据的时候如果老的坑可以满足那么就用去覆盖老坑但这里就会出现跟修改2一样的一个问题长度不是恰好切合的时候,后面数据读取的问题。
相关推荐
IT_陈寒1 小时前
Vue这个坑我跳了两次,原来问题出在这
前端·人工智能·后端
ServBay2 小时前
9 个 Python 第三方库推荐,不用 AI 都好像多出一个团队
后端·python
用户8356290780512 小时前
如何使用 Python 添加和管理 Excel 批注(完整示例)
后端·python
用户8356290780512 小时前
使用 Python 管理 Excel 工作表:创建、复制、删除与重命名
后端·python
SelectDB2 小时前
阶跃星辰基于 SelectDB 构建 PB 级 Agent 可观测平台
大数据·数据库·aigc
lizhongxuan2 小时前
Agent Tool
后端
CaffeinePro3 小时前
依赖注入:FastAPI最核心的解耦能力案例解析
后端·fastapi
这个DBA有点耶4 小时前
GROUP BY优化全解:如何写出既不丢数据又飞快的分组查询
数据库·mysql·架构
Assby4 小时前
从 Function Calling 到 MCP:理解 Agent 工具调用的底层通信机制
人工智能·后端
打字机v4 小时前
创建第一个spring-boot项目
后端