删除是一个很有意思的词
相近的词还取消,停用,不可见,弃置
不同的表达有不同的程度
在数据库的相关操作中
有很多关于删除的讨论,有人认为应该删除,有人认为不应该删除,而伴随着这些讨论的进行,软删除,硬删除这些词语眼花缭乱,给原本纷繁复杂的数据库语言又添加了不少术语。
通常情况下,我们所指的删除一般是物理删除,也就是硬删除,顾名思义,它将数据彻底地打到魂飞魄散,无影无踪,无论是从硬盘,内存,还是其他地方,这个数据都不复存在。而软删除相对柔和,它只是告诉别人,这条数据现在不可用,我们习惯给它挂个牌子,上面写着“Is_deleted=1”,这种做法是有利有弊,利于追踪数据,弊在数据量居高不下,系统反应缓慢,而且系统完整性和一致性都将经受挑战。
基于以上讨论,我的建议是功能分离,数据分开存储,这样保证了高性能的同时,不需要实际删除数据。
其实对于威盾的实时监控软件来说,它的做法就更加智能,它使用的是SQL SERVER,由于数据库的工作量巨大,它采用了一种动态在线,动态离线,动态备份的过程,这中实现很值得借鉴,完全将业务应用和决策分开,系统变得易扩展,高性能。