以下几个措施可以防止误删数据,如下:
-
生产环境中,业务代码尽量不明文保存数据库连接账号密码信息
-
重要的DML、DDL通过平台型工具自动实施,减少人工操作
-
部署延迟复制从库,万一误删除时用于数据回档,且从库设置为read-only
-
确认备份制度及时有效
-
启用SQL审计功能,养成良好SQL习惯
-
启用 sql_safe_updates 选项,不允许没 WHERE 条件的更新/删除
-
将系统层的rm改为mv
-
线上不进行物理删除,改为逻辑删除(将row data标记为不可用)
-
启用堡垒机,屏蔽高危SQL
-
降低数据库中普通账号的权限级别
-
务必开启binlog