精品欧美一区二区三区在线观看 _久久久久国色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技術棧公眾號

综合天堂av久久久久久久| 午夜av免费观看| 欧美3p视频| 欧美一区二区女人| 免费人成在线观看视频播放| 天天操天天射天天舔| 老牛国产精品一区的观看方式| 中文字幕精品—区二区| av地址在线观看| 成人性生交大片免费观看网站| 夜鲁夜鲁夜鲁视频在线播放| 亚洲精品一级二级三级| 欧美探花视频资源| 女人帮男人橹视频播放| 国产三级在线观看| 国产高清久久久| 国产成人高潮免费观看精品| 91高清免费观看| 亚洲理论电影| 日韩免费视频线观看| 精品www久久久久奶水| a视频在线免费看| 国产无人区一区二区三区| 666精品在线| 伊人网站在线观看| 国产欧美另类| 欧美大片在线看免费观看| 鲁丝一区二区三区| 精品久久ai| 制服丝袜成人动漫| 熟女人妇 成熟妇女系列视频| 国产成人无吗| 中文字幕国产一区| 欧美大陆一区二区| 黄片毛片在线看| 狠狠色丁香婷婷综合| 国产激情999| 男女视频免费看| 欧美成人有码| 久久综合国产精品台湾中文娱乐网| 女尊高h男高潮呻吟| 视频精品二区| 欧美一级黄色录像| 中文字幕第22页| 久久精品国产精品亚洲毛片| 色悠久久久久综合欧美99| 欧美日韩精品在线一区二区| 伊人春色在线观看| 亚洲丝袜另类动漫二区| 一区二区三区偷拍| 欧美成人精品一区二区男人看| 国产午夜精品一区二区三区视频| 久久久久久九九九九| 国产 日韩 欧美 综合| 国产精品伊人色| 91视频免费在线| 国产精品毛片一区视频播| 日日骚欧美日韩| 91成人性视频| 欧美啪啪小视频| 亚洲欧美日本国产专区一区| 91精品91久久久久久| 色婷婷av国产精品| 噜噜噜91成人网| 国产成人激情视频| 国产精品xxxxxx| 六月丁香婷婷色狠狠久久| 国产精品永久免费观看| 亚洲字幕av一区二区三区四区| 日本一不卡视频| 国产精品日韩电影| 91好色先生tv| 国产精品2024| 精品日本一区二区三区在线观看| 午夜视频福利在线| 久久亚洲一区二区三区四区| 日本在线成人一区二区| 色多多视频在线观看| 亚洲人成网站色在线观看| 伊人久久大香线蕉成人综合网| 麻豆av在线导航| 一区二区三区蜜桃网| 欧美国产视频一区| 午夜影视一区二区三区| 在线观看亚洲一区| 日日干日日操日日射| 国产情侣一区在线| 日韩成人激情视频| 一级特黄曰皮片视频| 91精品国产91久久综合| 久久欧美在线电影| 波多野结衣家庭主妇| 久久99精品久久久久久国产越南 | 丰满岳乱妇一区二区| 色天天色综合| 色哟哟亚洲精品一区二区| 中国一级片在线观看| 激情成人综合| 国产精品入口尤物| 亚洲免费一级片| 久久免费国产精品| 99热一区二区三区| 在线男人天堂| 欧美一二三区精品| 成人午夜剧场视频网站| 一级毛片免费高清中文字幕久久网| 久久久天堂国产精品女人| 特级西西444www高清大视频| 国产乱码一区二区三区| 日本一区不卡| 在线免费av导航| 欧美系列日韩一区| xxxx黄色片| 综合一区av| 国产精品欧美一区二区| 五月天婷婷在线观看| 成人欧美一区二区三区小说| 高清在线观看免费| 精品一区二区三区中文字幕在线 | 免费在线稳定资源站| 亚洲色图20p| 91激情视频在线| 精品久久对白| 九九视频这里只有精品| 性色av一区二区三区四区| 97aⅴ精品视频一二三区| 可以在线看黄的网站| 国精产品一区一区三区四川| 337p日本欧洲亚洲大胆色噜噜| 亚洲区一区二区三| 日韩国产精品久久久久久亚洲| 精品国产一区二区三区日日嗨 | 国产欧美精品一区aⅴ影院| 99热这里只有精品免费| 四虎国产精品永久在线国在线 | 97香蕉碰碰人妻国产欧美| 亚洲情侣在线| 国产日韩欧美在线观看| 国产精品一二三区视频| 欧美性猛交xxxx免费看| 黄色免费视频网站| 国产精品草草| 91在线播放视频| 天使と恶魔の榨精在线播放| 777精品伊人久久久久大香线蕉| 免费看的黄色网| 日韩精品成人一区二区三区| 欧美久久在线| 高清av不卡| 亚洲免费av片| 91玉足脚交嫩脚丫在线播放| 99re热视频精品| 日韩欧美亚洲天堂| 日本亚洲不卡| 日本高清视频精品| 精品亚洲综合| 欧美午夜理伦三级在线观看| 熟女少妇内射日韩亚洲| 奇米777欧美一区二区| 亚洲高清精品中出| 欧美黄色网络| 久久亚洲精品网站| www日本高清视频| 亚洲国产一区视频| 漂亮人妻被黑人久久精品| 一本综合久久| 日本视频精品一区| 欧美伊人亚洲伊人色综合动图| www.午夜精品| 亚洲va天堂va欧美ⅴa在线| 亚洲在线中文字幕| 国产肉体xxxx裸体784大胆| 午夜亚洲伦理| 亚洲国产精品视频一区| 精品国产一区二区三区2021| 久久99久久99精品中文字幕| 秋霞欧美在线观看| 91激情在线视频| www深夜成人a√在线| 粉嫩av一区二区三区| 亚欧无线一线二线三线区别| 国产videos久久| 国产欧美精品xxxx另类| 欧美四级在线| 亚洲无线码在线一区观看| 国产精品国产精品国产专区| 一区二区三区蜜桃| 精品无码在线观看| 国产盗摄一区二区三区| 97成人在线观看视频| 日韩在线视频精品| 国产精品国产精品国产专区不卡| 成人线上视频| 欧美超级免费视 在线| 亚洲色偷精品一区二区三区| 欧美日精品一区视频| 久久久久久久九九九九| 国产色一区二区| 国产成人av片| 日本美女一区二区三区视频| 蜜桃视频一区二区在线观看| 要久久爱电视剧全集完整观看| 成人观看高清在线观看免费| 超碰在线公开| 久久精品国产免费观看| 日韩中文字幕免费在线观看| 欧美三级日韩三级| 欧美不卡视频在线观看| 国产精品精品国产色婷婷| 国产伦精品一区二区免费| 久久精品国产一区二区三| 国产成人无码a区在线观看视频| 国产精品成人一区二区不卡| 精品国产一区二区三区久久久久久| 欧美午夜三级| 91成人国产在线观看| 人人澡人人添人人爽一区二区| 一区二区三区精品99久久 | 国产真实精品久久二三区| 久久综合色视频| 亚洲欧美综合国产精品一区| 亚洲精品不卡| 国产成人三级| 国产综合 伊人色| 亚洲精品a区| 91精品久久久久久久| 成人动漫一区| 97不卡在线视频| av有码在线观看| 欧美成人精品一区二区| 欧美激情黑人| 在线观看日韩视频| 国产私拍精品| 亚洲男人天堂视频| 神马电影在线观看| 日韩欧美亚洲另类制服综合在线 | 白浆在线视频| 久久免费少妇高潮久久精品99| a级影片在线| 久久在线免费视频| 成人黄视频在线观看| 久久夜色精品国产亚洲aⅴ| 97超碰人人在线| 深夜福利日韩在线看| 999在线视频| 色哟哟亚洲精品一区二区| 午夜老司机在线观看| 一区二区三区视频观看| 久久久久久久久亚洲精品| 亚洲区在线播放| 日韩三级电影网| 亚洲一区999| 91这里只有精品| 久久精品国产2020观看福利| 免费大片黄在线观看视频网站| 在线丨暗呦小u女国产精品| 国产天堂素人系列在线视频| 亚洲人成网站在线播| 国产一区电影| 神马久久久久久| av网站免费在线观看| 色综合久久天天综线观看| 91九色在线看| 91成人在线视频| 日韩av首页| 国产一区二区在线播放| 中文字幕亚洲在线观看| 国产日韩欧美二区| 日韩在线黄色| 亚洲综合网中心| 欧美日韩一区二区三区四区在线观看| a级免费在线观看| 亚洲一区欧美二区| 91极品尤物在线播放国产| 国产一级精品在线| 日韩av手机在线播放| 国产喷白浆一区二区三区| 蜜臀av午夜精品久久| 亚洲午夜在线视频| 无码人妻久久一区二区三区不卡| 欧美色精品在线视频| 国产精品一级视频| 亚洲精品国产精品国自产在线 | 色青青草原桃花久久综合 | 日韩美女精品在线| 久青草视频在线观看| 欧美丝袜一区二区三区| 成人黄色片在线观看| 精品久久人人做人人爱| 你懂的在线视频| 久久久成人av| 欧美xxxhd| 国产日韩欧美在线观看| 久久精品国产亚洲5555| 亚洲三区在线| 亚洲精品乱码久久久久久蜜桃麻豆| 免费国产成人av| 国产精品1区二区.| 日本二区在线观看| 亚洲在线视频一区| 中文字幕永久免费视频| 精品99999| 久草中文在线观看| 日韩av片免费在线观看| 亚洲视频三区| 一级做a爰片久久| 性一交一乱一区二区洋洋av| 欧美又黄又嫩大片a级| 久久婷婷一区二区三区| 欧美日韩在线观看成人| 欧美体内she精视频| 五十路在线观看| 国产精品三上| 亚洲影院色在线观看免费| 希岛爱理av免费一区二区| 日韩视频一二三| 蜜臀a∨国产成人精品| 熟妇高潮精品一区二区三区| 亚洲欧美日韩中文字幕一区二区三区| 国产在线观看黄色| 亚洲成人精品久久久| 18网站在线观看| 国产欧美日韩精品在线观看| 色爱综合av| 福利视频一二区| 国产精品123区| 日本中文在线视频| 欧美手机在线视频| 黄色片在线免费看| 欧美中文字幕在线观看| 噜噜噜天天躁狠狠躁夜夜精品 | 欧美日本免费| 污污的视频免费观看| 日本一区二区在线不卡| 日韩不卡在线播放| 日韩精品中文字| 蜜桃视频在线观看播放| 国产一区福利视频| 伊人久久成人| 999精品免费视频| 亚洲国产一区二区a毛片| 亚洲av无码乱码国产精品| 美女av一区二区三区| 亚洲ww精品| 中文字幕人成一区| 激情综合色综合久久综合| 视频国产一区二区| 91精品久久久久久久99蜜桃| 欧美成人xxx| 91久久精品国产91久久| 一本一道久久综合狠狠老| 两女双腿交缠激烈磨豆腐| 亚洲精品菠萝久久久久久久| 国产按摩一区二区三区| 欧美日韩xxx| 成午夜精品一区二区三区软件| 成人在线观看毛片| 成人网页在线观看| 国产精品100| 亚洲四色影视在线观看| 成人一级视频| 影音先锋成人资源网站| 成人一道本在线| 日韩精品成人一区| 亚洲性生活视频| 欧美一级做a| 97超碰在线视| 99久久精品国产一区二区三区| 日韩精品久久久久久久酒店| 亚洲毛片一区二区| 福利一区二区免费视频| 熟女视频一区二区三区| 成人妖精视频yjsp地址| 亚洲欧美综合另类| 中文字幕一区日韩电影| 视频二区欧美| 人妻熟女一二三区夜夜爱| 国产精品三级视频| 精品国产九九九| 18一19gay欧美视频网站| 欧美色就是色| 欧美熟妇精品一区二区| 日本韩国一区二区三区视频| 蜜桃av在线免费观看| 韩国一区二区三区美女美女秀| 日韩中文字幕不卡| 爱爱视频免费在线观看| 亚洲国产精品va在线看黑人| 91精品影视| 国产性生活免费视频| 国产午夜精品福利| 狠狠综合久久av一区二区| 国产精品盗摄久久久| 欧美精品色网| 免费看黄色三级| 日韩久久久精品| av久久网站| 精品少妇一区二区三区在线| 亚洲欧洲在线观看av| 亚洲人午夜射精精品日韩|