【MySQL】如何最大程度防止人为误操作MySQL数据库?这次我懂了!!
写在前面
今天,一位哥们打电话来问我说误操作了他们公司数据库中的数据,如何恢复。他原本的想法是登录数据库update一个记录,结果忘了加where条件,于是悲剧发生了。今天,我们不讲如何恢复误操作的数据(后面专门讲如何恢复误删除的数据),我们讲讲如何从源头上避免这样的问题,这才是避免类似问题的根本措施。
如果文章对你有所帮助,请不要吝惜你的点赞、在看、留言和转发,你的支持是我持续创作的最大动力!
在mysql命令加上选项-U后,当发出没有WHERE或LIMIT关键字的UPDATE或DELETE时,MySQL程序就会拒绝执行。那么,我们基于MySQL提供的这项设置,就可以轻松实现如何最大程度防止人为误操作MySQL数据库了。什么?你不信?不信我们就从MySQL的帮助说明说起,一起来看看如何基于MySQL的-u选项实现如何最大程度防止人为误操作MySQL数据库。
MySQL帮助说明
[root@binghe~]# mysql --help|grep dummy
-U, --i-am-a-dummy Synonym for option --safe-updates, -U.
i-am-a-dummy FALSE
在mysql命令加上选项-U后,当发出没有WHERE或LIMIT关键字的UPDATE或DELETE时,MySQL程序就会拒绝执行。
指定-U登录测试
[root@binghe~]# mysql -uroot -proot -S /data/3306/mysql.sock -U
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 14
Server version: 5.7.24-log MySQL Community Server (GPL)
Copyright (c) 2000, 2018, Oracle and/or its affiliates. All rights reserved.
Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
mysql> delete from oldboy.student;
ERROR 1175 (HY000): You are using safe update mode and you tried to update a table without a WHERE that uses a KEY column
mysql> quit
Bye
提示:不加条件无法删除,目的达到。
指定别名
我们可以将操作MySQL的命令做成别名,防止他人和DBA误操作数据库,将操作MySQL的命令做成别名也非常简单,这里,我们直接上示例了,如下所示。
[root@binghe~]# alias mysql='mysql -U'
[root@binghe~]# mysql -uroot -poldboy123 -S /data/3306/mysql.sock
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 15
Server version: 5.7.24-log MySQL Community Server (GPL)
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
mysql> delete from oldboy.student;
ERROR 1175 (HY000): You are using safe update mode and you tried to update a table without a WHERE that uses a KEY column
mysql> delete from oldboy.student where Sno=5;
Query OK, 1 row affected (0.02 sec)
mysql> quit
Bye
在命令行会话设置alias mysql='mysql -U'之后,只能在当前会话有效,关闭当前连接服务器的命令行之后,会话失效,则别名设置也会随之失效。如果想关闭连接服务器的会话终端,别名设置仍然有效,或者多个会话都能够使用这个别名来操作数据库,则我们可以将设置别名的命令添加到/etc/profile系统环境变量中,如下所示。
[root@binghe~]# echo "alias mysql='mysql -U'" >>/etc/profile
[root@binghe~]# . /etc/profile
[root@binghe~]# tail -1 /etc/profile
alias mysql='mysql -U'
这样,当我们退出当前连接服务器的会话终端,MySQL的别名设置依然有效,每次连接服务器时,不必在当前会话中重新设置MySQL的命令别名,直接使用即可。
总结
在mysql命令加上选项-U后,当发出没有WHERE或LIMIT关键字的UPDATE或DELETE时,MySQL程序拒绝执行。
重磅福利
关注「 冰河技术 」微信公众号,后台回复 “设计模式” 关键字领取《深入浅出Java 23种设计模式》PDF文档。回复“Java8”关键字领取《Java8新特性教程》PDF文档。回复“限流”关键字获取《亿级流量下的分布式限流解决方案》PDF文档,三本PDF均是由冰河原创并整理的超硬核教程,面试必备!!
好了,今天就聊到这儿吧!别忘了点个赞,给个在看和转发,让更多的人看到,一起学习,一起进步!!
写在最后
如果你觉得冰河写的还不错,请微信搜索并关注「 冰河技术 」微信公众号,跟冰河学习高并发、分布式、微服务、大数据、互联网和云原生技术,「 冰河技术 」微信公众号更新了大量技术专题,每一篇技术文章干货满满!不少读者已经通过阅读「 冰河技术 」微信公众号文章,吊打面试官,成功跳槽到大厂;也有不少读者实现了技术上的飞跃,成为公司的技术骨干!如果你也想像他们一样提升自己的能力,实现技术能力的飞跃,进大厂,升职加薪,那就关注「 冰河技术 」微信公众号吧,每天更新超硬核技术干货,让你对如何提升技术能力不再迷茫!
相关文章
- 构建MySQL数据库:掌握URL编码法(mysql数据库url)
- MySQL数据库存储优化探索(mysql存储优化的方法)
- MySQL数据库:免费软件下载体验(mysql数据库软件下载)
- 据库运维Mysql小型数据库的运维实践(mysql小数)
- MySQL数据库实时监控解决方案(mysql数据库监控工具)
- MySQL 导入时编码问题的解决方案(mysql导入编码)
- MySQL过程中创建临时表的方法(mysql过程临时表)
- 如何从备份中恢复MySQL表中的数据(mysql表恢复数据)
- 重置MySQL安装完成,密码重置一步到位(mysql安装后的密码)
- 如何在 MySQL 中保存图片:简单易懂的教程(mysql保存图片)
- MySQL 数据库的库表散列技术在数据分区和负载均衡方面的应用及优化(mysql库表散列)
- 如何使用MySQL查询所有列名(mysql查询所有列名)
- MySQL内连接语句:从一张表中读取数据(mysql内连接语句)
- MySQL启动异常,报错1067,如何解决?(mysql启动1067)
- 使用 MySQL 中的 操作符实现不等于的筛选条件(mysql操作符)
- MySQL的日期函数:获取当前年份(mysql当前年份)
- MySQL数据库文件遗失:如何恢复(mysql数据库文件丢失)
- Win7上如何安装和配置MySQL数据库?(win7mysql)
- MySQL数据库恢复:重新拥有自己的数据(使用mysql恢复数据库)
- MySQL数据库详解,完美掌握MySQL数据库之大全(mysql大全)
- MySQL如何处理回车符?(mysql回车符)
- MySQL的MVCC技术:实现数据库性能的优化篇(mvcc mysql)
- C程序实现数据上传至MySQL数据库(c 上传数据到mysql)
- MySQL 试试烹饪吧(cook mysql下载)
- MySQL数据库应用实例C语言编程实例(c mysql数据库例子)
- m参数的设置方法如何在MySQL中设置u参数或MySQL u参数的详细设置方法(mysql中-u)
- 如何安装32位Mysql数据库(32位mysql怎么装)
- MySQL数据库操作重点详解(mysql万字文档)
- 如何安装MySQL下载版(mysql下载了怎么安装)
- MySQL不支持全联,如何优化查询(mysql不支持全联)