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

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

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

由于最近在收集看一些数据库的东西,恰好昨晚听直播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一样的一个问题长度不是恰好切合的时候,后面数据读取的问题。
相关推荐
小白学鸿蒙1 分钟前
鸿蒙数据库表中的数据如何导出为Excel存到系统下载目录
数据库·excel·harmonyos
刘孬孬沉迷学习6 分钟前
5G网络gNB与核心网(5GC)连接架构及传输协议
网络·网络协议·tcp/ip·5g·架构·udp·信息与通信
lang2015092813 分钟前
Spring事务回滚规则深度解析
java·后端·spring
WKP941813 分钟前
mysql的事务、锁以及MVCC
数据库·mysql
文火冰糖的硅基工坊18 分钟前
[人工智能-大模型-78]:模型层技术 - 深度神经网络的网络架构的演进,这不仅是一条技术路线图,更是一部 “机器如何逐步逼近人类认知方式” 的进化史诗。
人工智能·架构·dnn
小虚竹21 分钟前
Tokio的多线程调度器架构:深度解析与实践
架构
那我掉的头发算什么29 分钟前
【数据库】增删改查 高阶(超级详细)保姆级教学
java·数据库·数据仓库·sql·mysql·性能优化·数据库架构
申阳38 分钟前
Day 1:耗时2小时,梳理并分享我作为全栈开发最依赖的“兵器库”
前端·后端·程序员
qq. 28040339841 小时前
nestjs引篇
后端·node.js·nestjs
雨夜赶路人1 小时前
SQL -- GROUP BY 基本语法
数据库·sql