精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

同事刪庫跑路后,我連表名都不能修改了?

數據庫 MySQL
從語句中可以拿到delete命令執行時每一行數據的值,這樣就可以進行數據的恢復了。如果需要恢復的數據量非常大的話,建議使用腳本批量將delete語句轉換為insert語句,減輕恢復數據的工作量。

[[424680]]

事情是這樣的,前幾天隔壁部門的哥們在生產環境的數據庫上,執行了一下drop命令,好嘛,活生生的刪庫跑路的例子居然真的在我身邊發生了,好在運維同學給力,后來恢復了數據。事后聽說這哥們雖然沒被開除,但也吃了個公司的警告。

再然后,運維那邊回收了所有環境下數據庫的drop命令的權限,甚至包括了開發環境,本來覺得對我們也沒啥影響,一般我們也沒有啥需要刪表的需求。但是隔了沒幾天,我在重命名一個表的時候,突然彈出了這樣一個報錯:

圖片

仔細看了一眼報錯:

  1. 1142 - DROP command denied to user 'hydra'@'localhost' for table 't_orders' 

什么情況,重命名表和drop命令還有什么關系?本著懷疑的態度,就想探究一下沒有drop權限后,對我們的日常數據庫操作都有什么影響,于是就有了后面一系列在本地進行的測試。

首先需要一個沒有drop權限的mysql用戶,我們先在本地環境使用root用戶登錄mysql,取消用戶hydra的drop權限。和grant授權命令相對應的,可以使用revoke命令取消對用戶的授權:

  1. revoke drop on *.* from hydra@'localhost'

好了,準備工作做完了,It's show time~

修改表名

前面直接使用navicat來修改表名失敗,那我們再用sql命令來嘗試一下:

上面測試了兩種重命名表的命令,無論是ALTER還是RENAME都不能正常使用,看來drop的權限確實會對修改表名造成影響。至于重命名失敗的原因,看一下官方文檔的說明:

RENAME TABLE renames one or more tables. You must have ALTER and DROP privileges for the original table, and CREATE and INSERT privileges for the new table.

簡單來說就是在重命名表時,必須有原始表的ALTER和DROP權限,以及新表的CREATE和INSERT權限。

truncate

當我需要清空一張表、順帶把AUTO_INCREMENT的主鍵置為初始值時,突然發現truncate命令也無法執行了:

有了上面的經驗,還是看一下官方文檔的說明:

Although TRUNCATE TABLE is similar to DELETE, it is classified as a DDL statement rather than a DML statement. It differs from DELETE in the following ways:

Truncate operations drop and re-create the table, which is much faster than deleting rows one by one, particularly for large tables.

文檔給出的解釋是盡管truncate和delete的功能很像,但是truncate被歸類為DDL語言,而delete則是DML語言。相對于delete一行行刪除數據,truncate會刪除表后重新新建表,這一操作相對delete會快很多,尤其是對大表而言。

從分類也可以看出兩者之間的不同,DML(data manipulation language)作為數據操作語言,主要是針對數據進行一些操作,例如常用的增刪改查。而DDL(data definition language)則是數據定義語言,主要應用于定義或改變表的結構等操作,并且這一操作過程是隱性提交的,不能回滾。

在truncate無法使用的情況下,來執行一下delete試試:

雖然說不帶where條件的delete刪除語句很不推薦使用,但是在功能上還是可以執行成功的。那么再看看另一個問題,表中的自增id重置了嗎?

我們知道,如果執行了truncate的話,那么自增列id的值會被重置為1。下面看看delete執行后的情況,插入一條數據并查詢:

通過上面的結果,可以看到使用delete清表后,自增列的值還是在原先的基礎上進行自增。如果需要重置這個值的話,需要我們手動在表上執行alter命令修改:

  1. alter table t_orders auto_increment= 1; 

drop作用范圍

那么,是否存在即使在沒有權限的情況下,也可以執行成功的drop指令?我們對不同對象分別進行測試,首先嘗試對數據庫、表、視圖的drop操作:

  1. drop DATABASE mall; 
  2. > 1044 - Access denied for user 'hydra'@'localhost' to database 'mall' 
  3. > 時間: 0.005s 
  4.  
  5. drop TABLE t_orders; 
  6. > 1142 - DROP command denied to user 'hydra'@'localhost' for table 't_orders' 
  7. > 時間: 0s 
  8.  
  9. drop VIEW order_view; 
  10. > 1142 - DROP command denied to user 'hydra'@'localhost' for table 'order_view' 
  11. > 時間: 0.001s 

上面這些命令理所當然的沒有執行成功,但是在嘗試到使用drop刪除存儲過程時,意料之外的結果出現了。在沒有drop權限的情況下,對存儲過程的drop操作,居然可以執行成功:

翻到官方文檔中授權這一章節,看一下這張圖就明白了:

上面的表進行了解釋,drop命令的作用范圍僅僅是數據庫、表以及視圖,而存儲過程的權限被單獨放在alter routine中了,因此即使沒有drop權限,我們仍可以用drop命令來刪除存儲過程。

delete后如何恢復數據

通過前面的實驗可以看到,雖然在回收drop權限后不能使用truncate清空數據表了,但我們仍然可以使用delete語句達到相同的效果,那么為什么delete就不害怕刪庫的風險呢?

前面我們提到過,delete語句屬于DDL語言,其實在實際的刪除過程中是一行行的進行刪除的,并且會將每行數據的刪除日志記錄在日志中,下面我們就看看如何利用binlog來恢復刪除的數據。

首先要求數據庫開啟binlog,使用下面的語句來查詢是否開啟:

  1. show variables like '%log_bin%'

在值為ON的情況下,表示開啟了binglog:

確保開啟了binlog后,我們使用delete來刪除表中的全部數據:

  1. delete from t_orders; 

在恢復刪除的數據前,需要先找到存放數據文件的目錄:

在該目錄下,存在若干名稱為mysql-bin.*****的文件,我們需要根據刪除操作發生的時間找到臨近的binglog文件:

找到目標binlog文件后,這里先將它拷貝到D:\tmp目錄下,然后到mysql安裝目錄的bin目錄下,執行下面的指令:

  1. mysqlbinlog --base64-output=decode-rows -v  
  2.   --database=mall  
  3.   --start-datetime="2021-09-17 20:50:00"  
  4.   --stop-datetime="2021-09-17 21:30:00"  
  5.   D:\tmp\mysql-bin.000001 > mysqllog.sql 

對參數進行一下說明:

  • base64-output=decode-rows:基于行事件解析成sql語句,并將數據轉換正常的字符
  • database:數據庫名
  • start-datetime:從binlog中第一個等于或晚于該時間戳的事件開始讀取,也就是恢復數據的起始時間
  • stop-datetime:與上面對應的,是恢復數據的結束時間
  • D:\tmp\mysql-bin.000001:恢復數據的日志文件
  • mysqllog.sql:恢復數據的輸出文件

執行完成后,在bin目錄下會生成一個mysqllog.sql的文件,打開文件看一下,可以找到刪除時執行的delete語句:

從語句中可以拿到delete命令執行時每一行數據的值,這樣就可以進行數據的恢復了。如果需要恢復的數據量非常大的話,建議使用腳本批量將delete語句轉換為insert語句,減輕恢復數據的工作量。

好了,如果你堅持看到這里,答應我,以后刪庫前,先看一下有沒有開啟binlog好嗎?

官方文檔:https://dev.mysql.com/doc/refman/5.7/en

【編輯推薦】

 

責任編輯:姜華 來源: 碼農參上
相關推薦

2018-09-21 11:34:42

災備

2018-09-25 09:11:59

2020-10-21 08:59:50

刪庫程序員虛擬機

2020-08-05 11:50:47

刪庫MySQL數據庫

2020-03-03 17:28:39

CIO刪庫微盟

2019-08-20 14:20:19

MySQL數據恢復數據庫

2024-03-29 08:08:25

2011-03-11 11:42:19

SAPSaaS云計算

2010-06-29 11:40:09

云計算公共云私有云

2019-10-21 09:36:06

互聯網數據技術

2021-03-15 08:24:32

Windows 10Windows微軟

2009-06-27 20:36:00

2021-03-13 12:05:54

微信朋友圈移動應用

2010-01-29 09:08:49

甲骨文收購SunJava

2009-01-16 14:38:24

經濟危機 CIO

2021-04-13 11:38:44

SASE零信任網絡安全

2022-06-13 11:43:15

數據庫MySQL索引

2024-01-24 07:30:45

MySQL數據庫索引

2021-07-22 07:50:47

刪庫系統數據

2017-09-11 10:09:59

刪庫DBA淘汰
點贊
收藏

51CTO技術棧公眾號

69av亚洲| 亚洲在线观看av| 欧美成人一区在线观看| 欧美色视频日本版| 亚洲精品在线视频观看| 高潮一区二区三区乱码| 亚洲女同同性videoxma| 日韩亚洲欧美中文高清在线| 超碰caoprom| 国产国产一区| 午夜视频一区二区| 亚洲一区三区电影在线观看| 亚洲高清视频网站| 日本美女一区二区| 久久免费精品视频| 国产成人精品视频免费| 国产精品毛片久久久| 精品1区2区3区| 日本免费不卡一区二区| 日韩伦理在线电影| 91视频一区二区| 99理论电影网| 国产精品久久久久久久久毛片 | 永久免费看av| 国产视频网站在线| 成人美女视频在线观看18| 国产精品久久久久久久av电影| 久久久久久天堂| 999国产精品999久久久久久| 精品视频在线播放免| 国产人妻精品午夜福利免费| 不卡亚洲精品| 一本久久a久久免费精品不卡| 美女av免费观看| 香蕉视频网站在线观看| 久久久噜噜噜久久人人看| 国产91aaa| 国产成人a人亚洲精品无码| 日韩电影在线观看一区| 55夜色66夜色国产精品视频| 国产一级性生活| 伊人久久大香线| 日韩在线免费视频观看| 亚洲色图欧美色| 狠狠色狠狠色综合婷婷tag| 日韩激情片免费| 99久久免费看精品国产一区| 一区二区三区自拍视频| 欧美一级艳片视频免费观看| 午夜精品免费看| 国产黄色精品| 欧美精品v国产精品v日韩精品| 999精品视频在线| 日本欧美一区| 欧美中文字幕一区二区三区 | 五月天国产一区| 成人精品福利| 国产精品萝li| 在线视频福利一区| 蜜桃视频网站在线观看| 成人欧美一区二区三区视频网页| 夜夜爽www精品| 免费看a在线观看| 亚洲色图清纯唯美| 国产毛片久久久久久国产毛片| 日本无删减在线| 亚洲不卡一区二区三区| 免费看一级大黄情大片| 亚洲天堂资源| 欧美在线短视频| 激情五月俺来也| 国产一区二区三区| 亚洲成人精品久久| 亚洲最大成人网站| 欧美激情成人| 久久99久久久久久久噜噜| 国产大片aaa| 麻豆精品网站| 成人a视频在线观看| 亚洲第一大网站| 91麻豆精东视频| 亚洲欧洲国产精品久久| 韩国av网站在线| 亚洲成人一区二区在线观看| 超碰网在线观看| 日韩色性视频| 亚洲高清色综合| 欧美多人猛交狂配| 午夜激情久久| 91精品国产91久久久久久不卡| 波多野结衣视频网址| 韩国v欧美v亚洲v日本v| 狠狠色综合色区| а天堂8中文最新版在线官网| 亚洲欧美日本韩国| av免费在线播放网站| 伊人久久大香线蕉综合影院首页| 亚洲国产精品悠悠久久琪琪| 欧美自拍偷拍网| 伊人蜜桃色噜噜激情综合| 国产精品wwwwww| 亚洲成人久久精品| 国产精品久久二区二区| 69sex久久精品国产麻豆| 日本中文字幕一区二区| 亚洲高清福利视频| 欧美成人777| 久久精品1区| 国产v亚洲v天堂无码| 91伦理视频在线观看| 精品免费在线视频| 熟妇女人妻丰满少妇中文字幕| 久久av超碰| 国内久久久精品| 国产精品一级视频| 国产三级一区二区| 僵尸世界大战2 在线播放| 欧美午夜三级| 亚洲视频axxx| 成年人免费高清视频| 国产乱人伦偷精品视频不卡| 午夜午夜精品一区二区三区文| 国产盗摄在线视频网站| 91麻豆精品久久久久蜜臀| 夜夜春很很躁夜夜躁| 国产精品一二| 精品久久久久久一区| 男女免费观看在线爽爽爽视频| 欧美日韩国产首页在线观看| japanese中文字幕| 99精品视频免费观看视频| 99久久无色码| 97caopron在线视频| 欧美人与性动xxxx| jizzjizzjizz国产| 日本vs亚洲vs韩国一区三区二区| 久久久精品国产一区二区三区| 欧美xxxx视频| 精品免费国产二区三区| 国产高潮流白浆| 韩国欧美国产1区| 在线精品亚洲一区二区| 日韩欧美三区| 久久婷婷国产麻豆91天堂| 亚洲一级片免费看| 国产精品网站导航| 日韩一级免费片| 999精品视频| 成人亚洲激情网| bestiality新另类大全| 日韩视频在线观看一区二区| 欧美日韩精品亚洲精品| 国产·精品毛片| 免费特级黄色片| 日韩av黄色在线| 欧美在线性爱视频| 久久米奇亚洲| 欧美日韩一区二区三区四区五区 | 日韩av在线播放网址| 国产欧美一区二区三区视频 | 国产成人一区| 国产精品视频久| 毛片在线播放a| 欧美一二三在线| 国产无码精品久久久| 91女厕偷拍女厕偷拍高清| 农村妇女精品一二区| 日韩久久精品| yellow视频在线观看一区二区| 青春草免费在线视频| 日韩av在线网址| 波多野结衣理论片| 亚洲男人的天堂av| av网站有哪些| 蜜臀久久99精品久久久画质超高清 | 欧美一级色片| 国产精品福利无圣光在线一区| av资源网站在线观看| 91麻豆精品国产91久久久使用方法| 国语对白在线播放| 成人精品免费视频| 日本男人操女人| 欧美在线亚洲| 免费中文日韩| 久久99成人| 青青草精品毛片| 国产最新在线| 亚洲精品久久久一区二区三区| 无码人妻丰满熟妇区五十路| 中文字幕一区二区三区在线播放 | 视频精品一区二区三区| 午夜剧场成人观在线视频免费观看| 欧美91精品久久久久国产性生爱| 欧美日韩在线免费视频| 日本熟女一区二区| 中文字幕欧美日韩一区| 任你躁av一区二区三区| 日本中文字幕一区二区有限公司| 国产激情在线看| 国产欧美日韩精品一区二区免费| 91久久嫩草影院一区二区| 中文字幕在线高清| 欧美超级乱淫片喷水| 邻家有女韩剧在线观看国语| 日韩欧美自拍偷拍| 中国黄色一级视频| 午夜电影久久久| 免费精品在线视频| 久久五月婷婷丁香社区| 亚洲区 欧美区| 精品一区二区三区久久久| 免费黄色日本网站| 亚洲性视频h| 午夜在线视频免费观看| 精品精品久久| 精品国产免费人成电影在线观... 精品国产免费久久久久久尖叫 | 天堂v在线观看| 8v天堂国产在线一区二区| 亚洲国产成人无码av在线| 亚洲自拍偷拍麻豆| 久久噜噜色综合一区二区| 国产丝袜在线精品| 国产精品无码一区二区三| 国产乱码精品一区二区三| 国产精品视频分类| 丝袜美腿亚洲一区二区图片| 五十路熟女丰满大屁股| 午夜国产精品视频| 在线视频不卡一区二区| 成人中文视频| 日韩区国产区| 色综合中文网| 欧美大陆一区二区| 日本韩国欧美超级黄在线观看| 99视频在线免费观看| 自拍偷拍欧美日韩| 91精品久久久久久久久久久久久 | 欧美日韩在线不卡| 成人午夜精品视频| 欧美自拍偷拍一区| 成人免费一级片| 欧美中文字幕不卡| 国产免费www| 在线观看区一区二| 一区二区视频免费| 欧美日韩大陆一区二区| 中文字幕乱码一区二区| 欧美亚洲国产怡红院影院| 人人爽人人爽人人片av| 日韩欧美在线国产| 成人免费视频国产免费| 色婷婷久久久久swag精品| 婷婷激情五月综合| 欧美日韩卡一卡二| 国产色在线视频| 欧美一区二区三级| 欧美一级片免费| 亚洲精品一区二三区不卡| 精品视频二区| 中文字幕在线观看亚洲| 国产剧情在线| 国产+人+亚洲| 在线视频cao| 国产精品1234| 北岛玲精品视频在线观看| 97超碰资源| 欧美在线导航| 色噜噜狠狠一区二区三区| 国产精品精品| 精品一区二区三区无码视频| 一本色道精品久久一区二区三区 | 一区二区视频在线播放| 女人天堂亚洲aⅴ在线观看| 亚洲国产精品无码av| 性一交一乱一区二区洋洋av| 男操女免费网站| 国产一区二区三区av电影 | 免费大片在线观看| 久久成人免费网| 欧美一级大片免费看| 91视频一区二区| 一区二区三区影视| 午夜国产不卡在线观看视频| 中国精品一区二区| 精品美女在线观看| 91.xxx.高清在线| 久久久久久999| 欧美日韩国产网站| 成人黄动漫网站免费| 国产日韩视频在线| 欧美 日韩 国产精品| 日韩在线观看一区二区| 男人女人拔萝卜视频| 久久精品一区四区| 久草视频在线资源站| 91国产福利在线| 成人av免费播放| 伊人久久男人天堂| 9999精品成人免费毛片在线看| 国产精品久久久av| 精品中国亚洲| 国产三级中文字幕| 日韩av一级片| 99久久人妻精品免费二区| 亚洲色图欧美激情| 国产精品午夜一区二区| 精品国产乱码久久久久久老虎 | 国产精品22p| 天堂v在线视频| 久久男女视频| 久久久久亚洲无码| 亚洲精品乱码久久久久| 中文字幕av第一页| 亚洲精品自拍视频| 暧暧视频在线免费观看| 亚洲bt欧美bt日本bt| 欧美日韩激情| 国产精品后入内射日本在线观看| 国产精品18久久久久久久久久久久 | 国产无套内射久久久国产| 国产精品1区二区.| 亚洲不卡在线播放| 欧美日韩午夜精品| 国产二区视频在线观看| 欧美亚洲在线视频| 韩国女主播一区二区三区| 天天综合五月天| 麻豆国产欧美日韩综合精品二区 | 空姐吹箫视频大全| 欧美区在线播放| 精品欧美视频| 操bbb操bbb| 国产麻豆欧美日韩一区| 婷婷国产成人精品视频| 欧美视频中文一区二区三区在线观看| 欧洲视频在线免费观看| 992tv成人免费影院| 99国产精品免费网站| 久久香蕉视频网站| 国产精品自拍一区| 波多野结衣爱爱视频| 欧美一区在线视频| 黄网站app在线观看| 成人免费视频网址| 久久精品高清| 一级淫片在线观看| 亚洲久本草在线中文字幕| av手机免费看| 欧美激情综合色| 国产一区调教| 一本大道熟女人妻中文字幕在线| 91亚洲精品久久久蜜桃网站| 亚洲日本视频在线观看| 亚洲欧美另类中文字幕| 久久久成人av毛片免费观看| 神马一区二区影院| 久久av老司机精品网站导航| 在线观看美女av| 日韩免费一区二区三区在线播放| 牛牛精品在线视频| 国产精品一区二区不卡视频| 亚洲高清毛片| www.色天使| 欧美三级蜜桃2在线观看| 麻豆tv在线| 国产精品免费在线播放| 一区二区三区国产在线| 91网站免费视频| 欧美精品久久99| 国产www视频在线观看| 欧美成ee人免费视频| 久久精品国内一区二区三区 | 欧美性猛交视频| 成黄免费在线| 99热在线国产| 美女国产一区| 在线观看亚洲网站| 亚洲第一av网站| 性欧美18一19sex性欧美| 一区二区在线观| 99久久精品免费看国产 | 日韩一级成人av| sm久久捆绑调教精品一区| 日本高清视频一区二区三区 | 亚洲综合在线播放| 在线亚洲免费| 香蕉成人在线视频| 亚洲精品99久久久久中文字幕| 色猫猫成人app| 欧美中日韩在线| 亚洲国产成人在线| 日本高清视频免费观看| 国产精品视频男人的天堂| 国内精品久久久久久久影视蜜臀 | 男生操女生视频在线观看 | 日韩在线观看av| 欧美成人专区| 一卡二卡三卡四卡五卡| 色av成人天堂桃色av| 欧洲成人综合网|