91欧美超碰AV自拍|国产成年人性爱视频免费看|亚洲 日韩 欧美一厂二区入|人人看人人爽人人操aV|丝袜美腿视频一区二区在线看|人人操人人爽人人爱|婷婷五月天超碰|97色色欧美亚州A√|另类A√无码精品一级av|欧美特级日韩特级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫(xiě)文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

數(shù)據(jù)庫(kù)索引使用策略及優(yōu)化

C語(yǔ)言編程學(xué)習(xí)基地 ? 來(lái)源:C語(yǔ)言編程學(xué)習(xí)基地 ? 作者:C語(yǔ)言編程學(xué)習(xí)基地 ? 2021-11-02 15:13 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

索引使用策略及優(yōu)化

MySQL的優(yōu)化主要分為結(jié)構(gòu)優(yōu)化(Scheme optimization)和查詢(xún)優(yōu)化(Query optimization)。本章討論的高性能索引策略主要屬于結(jié)構(gòu)優(yōu)化范疇。本章的內(nèi)容完全基于上文的理論基礎(chǔ),實(shí)際上一旦理解了索引背后的機(jī)制,那么選擇高性能的策略就變成了純粹的推理,并且可以理解這些策略背后的邏輯。

示例數(shù)據(jù)庫(kù)

為了討論索引策略,需要一個(gè)數(shù)據(jù)量不算小的數(shù)據(jù)庫(kù)作為示例。本文選用MySQL官方文檔中提供的示例數(shù)據(jù)庫(kù)之一:employees。這個(gè)數(shù)據(jù)庫(kù)關(guān)系復(fù)雜度適中,且數(shù)據(jù)量較大。下圖是這個(gè)數(shù)據(jù)庫(kù)的E-R關(guān)系圖(引用自MySQL官方手冊(cè))

MySQL官方文檔中關(guān)于此數(shù)據(jù)庫(kù)的頁(yè)面為http://dev.mysql.com/doc/employee/en/employee.html。里面詳細(xì)介紹了此數(shù)據(jù)庫(kù),并提供了下載地址和導(dǎo)入方法,如果有興趣導(dǎo)入此數(shù)據(jù)庫(kù)到自己的MySQL可以參考文中內(nèi)容。

最左前綴原理與相關(guān)優(yōu)化

高效使用索引的首要條件是知道什么樣的查詢(xún)會(huì)使用到索引,這個(gè)問(wèn)題和B+Tree中的“最左前綴原理”有關(guān),下面通過(guò)例子說(shuō)明最左前綴原理。

這里先說(shuō)一下聯(lián)合索引的概念。在上文中,我們都是假設(shè)索引只引用了單個(gè)的列,實(shí)際上,MySQL中的索引可以以一定順序引用多個(gè)列,這種索引叫做聯(lián)合索引,一般的,一個(gè)聯(lián)合索引是一個(gè)有序元組《a1, a2, …, an》,其中各個(gè)元素均為數(shù)據(jù)表的一列,實(shí)際上要嚴(yán)格定義索引需要用到關(guān)系代數(shù),但是這里我不想討論太多關(guān)系代數(shù)的話題,因?yàn)槟菢訒?huì)顯得很枯燥,所以這里就不再做嚴(yán)格定義。另外,單列索引可以看成聯(lián)合索引元素?cái)?shù)為1的特例。

以employees.titles表為例,下面先查看其上都有哪些索引:

33cd2c5a-38ac-11ec-82a8-dac502259ad0.png

從結(jié)果中可以到titles表的主索引為《emp_no, title, from_date》,還有一個(gè)輔助索引《emp_no》。為了避免多個(gè)索引使事情變復(fù)雜(MySQL的SQL優(yōu)化器在多索引時(shí)行為比較復(fù)雜),這里我們將輔助索引drop掉:

3464b124-38ac-11ec-82a8-dac502259ad0.png

這樣就可以專(zhuān)心分析索引PRIMARY的行為了。

情況一:全列匹配。

34bbe688-38ac-11ec-82a8-dac502259ad0.png

很明顯,當(dāng)按照索引中所有列進(jìn)行精確匹配(這里精確匹配指“=”或“IN”匹配)時(shí),索引可以被用到。這里有一點(diǎn)需要注意,理論上索引對(duì)順序是敏感的,但是由于MySQL的查詢(xún)優(yōu)化器會(huì)自動(dòng)調(diào)整where子句的條件順序以使用適合的索引,例如我們將where中的條件順序顛倒:

35360828-38ac-11ec-82a8-dac502259ad0.png

效果是一樣的。

情況二:最左前綴匹配。

35bc4276-38ac-11ec-82a8-dac502259ad0.png

當(dāng)查詢(xún)條件精確匹配索引的左邊連續(xù)一個(gè)或幾個(gè)列時(shí),如《emp_no》或《emp_no, title》,所以可以被用到,但是只能用到一部分,即條件所組成的最左前綴。上面的查詢(xún)從分析結(jié)果看用到了PRIMARY索引,但是key_len為4,說(shuō)明只用到了索引的第一列前綴。

情況三:查詢(xún)條件用到了索引中列的精確匹配,但是中間某個(gè)條件未提供。

3614f344-38ac-11ec-82a8-dac502259ad0.png

此時(shí)索引使用情況和情況二相同,因?yàn)閠itle未提供,所以查詢(xún)只用到了索引的第一列,而后面的from_date雖然也在索引中,但是由于title不存在而無(wú)法和左前綴連接,因此需要對(duì)結(jié)果進(jìn)行掃描過(guò)濾from_date(這里由于emp_no唯一,所以不存在掃描)。如果想讓from_date也使用索引而不是where過(guò)濾,可以增加一個(gè)輔助索引《emp_no, from_date》,此時(shí)上面的查詢(xún)會(huì)使用這個(gè)索引。除此之外,還可以使用一種稱(chēng)之為“隔離列”的優(yōu)化方法,將emp_no與from_date之間的“坑”填上。

首先我們看下title一共有幾種不同的值:

36a100fa-38ac-11ec-82a8-dac502259ad0.png

只有7種。在這種成為“坑”的列值比較少的情況下,可以考慮用“IN”來(lái)填補(bǔ)這個(gè)“坑”從而形成最左前綴:

370dbbe6-38ac-11ec-82a8-dac502259ad0.png

這次key_len為59,說(shuō)明索引被用全了,但是從type和rows看出IN實(shí)際上執(zhí)行了一個(gè)range查詢(xún),這里檢查了7個(gè)key。看下兩種查詢(xún)的性能比較:

378b3a80-38ac-11ec-82a8-dac502259ad0.png

“填坑”后性能提升了一點(diǎn)。如果經(jīng)過(guò)emp_no篩選后余下很多數(shù)據(jù),則后者性能優(yōu)勢(shì)會(huì)更加明顯。當(dāng)然,如果title的值很多,用填坑就不合適了,必須建立輔助索引。

情況四:查詢(xún)條件沒(méi)有指定索引第一列。

38088d32-38ac-11ec-82a8-dac502259ad0.png

由于不是最左前綴,索引這樣的查詢(xún)顯然用不到索引。

情況五:匹配某列的前綴字符串。

387ac6ae-38ac-11ec-82a8-dac502259ad0.png

此時(shí)可以用到索引,但是如果通配符不是只出現(xiàn)在末尾,則無(wú)法使用索引。(原文表述有誤,如果通配符%不出現(xiàn)在開(kāi)頭,則可以用到索引,但根據(jù)具體情況不同可能只會(huì)用其中一個(gè)前綴)

情況六:范圍查詢(xún)。

38de2d70-38ac-11ec-82a8-dac502259ad0.png

范圍列可以用到索引(必須是最左前綴),但是范圍列后面的列無(wú)法用到索引。同時(shí),索引最多用于一個(gè)范圍列,因此如果查詢(xún)條件中有兩個(gè)范圍列則無(wú)法全用到索引。

39582058-38ac-11ec-82a8-dac502259ad0.png

可以看到索引對(duì)第二個(gè)范圍索引無(wú)能為力。這里特別要說(shuō)明MySQL一個(gè)有意思的地方,那就是僅用explain可能無(wú)法區(qū)分范圍索引和多值匹配,因?yàn)樵趖ype中這兩者都顯示為range。同時(shí),用了“between”并不意味著就是范圍查詢(xún),例如下面的查詢(xún):

39d63678-38ac-11ec-82a8-dac502259ad0.png

看起來(lái)是用了兩個(gè)范圍查詢(xún),但作用于emp_no上的“BETWEEN”實(shí)際上相當(dāng)于“IN”,也就是說(shuō)emp_no實(shí)際是多值精確匹配。可以看到這個(gè)查詢(xún)用到了索引全部三個(gè)列。因此在MySQL中要謹(jǐn)慎地區(qū)分多值匹配和范圍匹配,否則會(huì)對(duì)MySQL的行為產(chǎn)生困惑。

情況七:查詢(xún)條件中含有函數(shù)或表達(dá)式。

很不幸,如果查詢(xún)條件中含有函數(shù)或表達(dá)式,則MySQL不會(huì)為這列使用索引(雖然某些在數(shù)學(xué)意義上可以使用)。例如:

3a533844-38ac-11ec-82a8-dac502259ad0.png

雖然這個(gè)查詢(xún)和情況五中功能相同,但是由于使用了函數(shù)left,則無(wú)法為title列應(yīng)用索引,而情況五中用LIKE則可以。再如:

3ae3a2b2-38ac-11ec-82a8-dac502259ad0.png

顯然這個(gè)查詢(xún)等價(jià)于查詢(xún)emp_no為10001的函數(shù),但是由于查詢(xún)條件是一個(gè)表達(dá)式,MySQL無(wú)法為其使用索引??磥?lái)MySQL還沒(méi)有智能到自動(dòng)優(yōu)化常量表達(dá)式的程度,因此在寫(xiě)查詢(xún)語(yǔ)句時(shí)盡量避免表達(dá)式出現(xiàn)在查詢(xún)中,而是先手工私下代數(shù)運(yùn)算,轉(zhuǎn)換為無(wú)表達(dá)式的查詢(xún)語(yǔ)句。

索引選擇性與前綴索引

既然索引可以加快查詢(xún)速度,那么是不是只要是查詢(xún)語(yǔ)句需要,就建上索引?答案是否定的。因?yàn)樗饕m然加快了查詢(xún)速度,但索引也是有代價(jià)的:索引文件本身要消耗存儲(chǔ)空間,同時(shí)索引會(huì)加重插入、刪除和修改記錄時(shí)的負(fù)擔(dān),另外,MySQL在運(yùn)行時(shí)也要消耗資源維護(hù)索引,因此索引并不是越多越好。一般兩種情況下不建議建索引。

第一種情況是表記錄比較少,例如一兩千條甚至只有幾百條記錄的表,沒(méi)必要建索引,讓查詢(xún)做全表掃描就好了。至于多少條記錄才算多,這個(gè)個(gè)人有個(gè)人的看法,我個(gè)人的經(jīng)驗(yàn)是以2000作為分界線,記錄數(shù)不超過(guò) 2000可以考慮不建索引,超過(guò)2000條可以酌情考慮索引。

另一種不建議建索引的情況是索引的選擇性較低。所謂索引的選擇性(Selectivity),是指不重復(fù)的索引值(也叫基數(shù),Cardinality)與表記錄數(shù)(#T)的比值:

Index Selectivity = Cardinality / #T

顯然選擇性的取值范圍為(0, 1],選擇性越高的索引價(jià)值越大,這是由B+Tree的性質(zhì)決定的。例如,上文用到的employees.titles表,如果title字段經(jīng)常被單獨(dú)查詢(xún),是否需要建索引,我們看一下它的選擇性:

3b79c1e8-38ac-11ec-82a8-dac502259ad0.png

title的選擇性不足0.0001(精確值為0.00001579),所以實(shí)在沒(méi)有什么必要為其單獨(dú)建索引。

有一種與索引選擇性有關(guān)的索引優(yōu)化策略叫做前綴索引,就是用列的前綴代替整個(gè)列作為索引key,當(dāng)前綴長(zhǎng)度合適時(shí),可以做到既使得前綴索引的選擇性接近全列索引,同時(shí)因?yàn)樗饕齥ey變短而減少了索引文件的大小和維護(hù)開(kāi)銷(xiāo)。下面以employees.employees表為例介紹前綴索引的選擇和使用。

從圖12可以看到employees表只有一個(gè)索引《emp_no》,那么如果我們想按名字搜索一個(gè)人,就只能全表掃描了:

3bfe4c56-38ac-11ec-82a8-dac502259ad0.png

如果頻繁按名字搜索員工,這樣顯然效率很低,因此我們可以考慮建索引。有兩種選擇,建《first_name》或《first_name, last_name》,看下兩個(gè)索引的選擇性:

3c89b5c0-38ac-11ec-82a8-dac502259ad0.png

《first_name》顯然選擇性太低,《first_name, last_name》選擇性很好,但是first_name和last_name加起來(lái)長(zhǎng)度為30,有沒(méi)有兼顧長(zhǎng)度和選擇性的辦法?可以考慮用first_name和last_name的前幾個(gè)字符建立索引,例如《first_name, left(last_name, 3)》,看看其選擇性:

3d0cf958-38ac-11ec-82a8-dac502259ad0.png

選擇性還不錯(cuò),但離0.9313還是有點(diǎn)距離,那么把last_name前綴加到4:

3d9ea646-38ac-11ec-82a8-dac502259ad0.png

這時(shí)選擇性已經(jīng)很理想了,而這個(gè)索引的長(zhǎng)度只有18,比《first_name, last_name》短了接近一半,我們把這個(gè)前綴索引 建上:

3e27458c-38ac-11ec-82a8-dac502259ad0.png

此時(shí)再執(zhí)行一遍按名字查詢(xún),比較分析一下與建索引前的結(jié)果:

3e908c2c-38ac-11ec-82a8-dac502259ad0.png

性能的提升是顯著的,查詢(xún)速度提高了120多倍。

前綴索引兼顧索引大小和查詢(xún)速度,但是其缺點(diǎn)是不能用于ORDER BY和GROUP BY操作,也不能用于Covering index(即當(dāng)索引本身包含查詢(xún)所需全部數(shù)據(jù)時(shí),不再訪問(wèn)數(shù)據(jù)文件本身)。

InnoDB的主鍵選擇與插入優(yōu)化

在使用InnoDB存儲(chǔ)引擎時(shí),如果沒(méi)有特別的需要,請(qǐng)永遠(yuǎn)使用一個(gè)與業(yè)務(wù)無(wú)關(guān)的自增字段作為主鍵。

經(jīng)??吹接刑踊虿┛陀懻撝麈I選擇問(wèn)題,有人建議使用業(yè)務(wù)無(wú)關(guān)的自增主鍵,有人覺(jué)得沒(méi)有必要,完全可以使用如學(xué)號(hào)或身份證號(hào)這種唯一字段作為主鍵。不論支持哪種論點(diǎn),大多數(shù)論據(jù)都是業(yè)務(wù)層面的。如果從數(shù)據(jù)庫(kù)索引優(yōu)化角度看,使用InnoDB引擎而不使用自增主鍵絕對(duì)是一個(gè)糟糕的主意。

上文討論過(guò)InnoDB的索引實(shí)現(xiàn),InnoDB使用聚集索引,數(shù)據(jù)記錄本身被存于主索引(一顆B+Tree)的葉子節(jié)點(diǎn)上。這就要求同一個(gè)葉子節(jié)點(diǎn)內(nèi)(大小為一個(gè)內(nèi)存頁(yè)或磁盤(pán)頁(yè))的各條數(shù)據(jù)記錄按主鍵順序存放,因此每當(dāng)有一條新的記錄插入時(shí),MySQL會(huì)根據(jù)其主鍵將其插入適當(dāng)?shù)墓?jié)點(diǎn)和位置,如果頁(yè)面達(dá)到裝載因子(InnoDB默認(rèn)為15/16),則開(kāi)辟一個(gè)新的頁(yè)(節(jié)點(diǎn))。

如果表使用自增主鍵,那么每次插入新的記錄,記錄就會(huì)順序添加到當(dāng)前索引節(jié)點(diǎn)的后續(xù)位置,當(dāng)一頁(yè)寫(xiě)滿(mǎn),就會(huì)自動(dòng)開(kāi)辟一個(gè)新的頁(yè)。如下圖所示:

這樣就會(huì)形成一個(gè)緊湊的索引結(jié)構(gòu),近似順序填滿(mǎn)。由于每次插入時(shí)也不需要移動(dòng)已有數(shù)據(jù),因此效率很高,也不會(huì)增加很多開(kāi)銷(xiāo)在維護(hù)索引上。

如果使用非自增主鍵(如果身份證號(hào)或?qū)W號(hào)等),由于每次插入主鍵的值近似于隨機(jī),因此每次新紀(jì)錄都要被插到現(xiàn)有索引頁(yè)得中間某個(gè)位置:

此時(shí)MySQL不得不為了將新記錄插到合適位置而移動(dòng)數(shù)據(jù),甚至目標(biāo)頁(yè)面可能已經(jīng)被回寫(xiě)到磁盤(pán)上而從緩存中清掉,此時(shí)又要從磁盤(pán)上讀回來(lái),這增加了很多開(kāi)銷(xiāo),同時(shí)頻繁的移動(dòng)、分頁(yè)操作造成了大量的碎片,得到了不夠緊湊的索引結(jié)構(gòu),后續(xù)不得不通過(guò)OPTIMIZE TABLE來(lái)重建表并優(yōu)化填充頁(yè)面。

因此,只要可以,請(qǐng)盡量在InnoDB上采用自增字段做主鍵。

后記

這篇文章斷斷續(xù)續(xù)寫(xiě)了半個(gè)月,主要內(nèi)容就是上面這些了。不可否認(rèn),這篇文章在一定程度上有紙上談兵之嫌,因?yàn)槲冶救藢?duì)MySQL的使用屬于菜鳥(niǎo)級(jí)別,更沒(méi)有太多數(shù)據(jù)庫(kù)調(diào)優(yōu)的經(jīng)驗(yàn),在這里大談數(shù)據(jù)庫(kù)索引調(diào)優(yōu)有點(diǎn)大言不慚。就當(dāng)是我個(gè)人的一篇學(xué)習(xí)筆記了。

其實(shí)數(shù)據(jù)庫(kù)索引調(diào)優(yōu)是一項(xiàng)技術(shù)活,不能僅僅靠理論,因?yàn)閷?shí)際情況千變?nèi)f化,而且MySQL本身存在很復(fù)雜的機(jī)制,如查詢(xún)優(yōu)化策略和各種引擎的實(shí)現(xiàn)差異等都會(huì)使情況變得更加復(fù)雜。但同時(shí)這些理論是索引調(diào)優(yōu)的基礎(chǔ),只有在明白理論的基礎(chǔ)上,才能對(duì)調(diào)優(yōu)策略進(jìn)行合理推斷并了解其背后的機(jī)制,然后結(jié)合實(shí)踐中不斷的實(shí)驗(yàn)和摸索,從而真正達(dá)到高效使用MySQL索引的目的。

另外,MySQL索引及其優(yōu)化涵蓋范圍非常廣,本文只是涉及到其中一部分。如與排序(ORDER BY)相關(guān)的索引優(yōu)化及覆蓋索引(Covering index)的話題本文并未涉及,同時(shí)除B-Tree索引外MySQL還根據(jù)不同引擎支持的哈希索引、全文索引等等本文也并未涉及。如果有機(jī)會(huì),希望再對(duì)本文未涉及的部分進(jìn)行補(bǔ)充吧。

責(zé)任編輯:haq

聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 數(shù)據(jù)庫(kù)
    +關(guān)注

    關(guān)注

    7

    文章

    4018

    瀏覽量

    68326
  • C++
    C++
    +關(guān)注

    關(guān)注

    22

    文章

    2123

    瀏覽量

    77104

原文標(biāo)題:C++基礎(chǔ)語(yǔ)法梳理:數(shù)據(jù)庫(kù)丨索引使用和優(yōu)化

文章出處:【微信號(hào):cyuyanxuexi,微信公眾號(hào):C語(yǔ)言編程學(xué)習(xí)基地】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    深度解讀MySQL數(shù)據(jù)庫(kù)備份恢復(fù)策略

    數(shù)據(jù)是企業(yè)的核心資產(chǎn),數(shù)據(jù)庫(kù)備份是保障數(shù)據(jù)安全的最后一道防線。某天上午10點(diǎn),運(yùn)營(yíng)人員誤執(zhí)行了一條DELETE語(yǔ)句,刪除了訂單表中近一個(gè)月的數(shù)據(jù),影響了數(shù)萬(wàn)筆訂單。如果沒(méi)有完善的備份
    的頭像 發(fā)表于 01-26 17:40 ?613次閱讀

    國(guó)產(chǎn)數(shù)據(jù)庫(kù)的AI戰(zhàn)事

    國(guó)產(chǎn)數(shù)據(jù)庫(kù)硝煙再起,Vastbase V100構(gòu)筑企業(yè)智能基座
    的頭像 發(fā)表于 10-24 20:45 ?4010次閱讀
    國(guó)產(chǎn)<b class='flag-5'>數(shù)據(jù)庫(kù)</b>的AI戰(zhàn)事

    華納云香港服務(wù)器數(shù)據(jù)庫(kù)索引優(yōu)化策略

    )實(shí)施有效的索引優(yōu)化策略。無(wú)論您是IT管理員還是開(kāi)發(fā)人員,了解這些技巧都能幫助您優(yōu)化數(shù)據(jù)庫(kù)效率,確保業(yè)務(wù)高效運(yùn)轉(zhuǎn)。下面,華納云(hnclou
    的頭像 發(fā)表于 10-16 17:06 ?514次閱讀

    數(shù)據(jù)庫(kù)慢查詢(xún)分析與SQL優(yōu)化實(shí)戰(zhàn)技巧

    今天,我將分享我在處理數(shù)千次數(shù)據(jù)庫(kù)性能問(wèn)題中積累的實(shí)戰(zhàn)經(jīng)驗(yàn),幫助你系統(tǒng)掌握慢查詢(xún)分析與SQL優(yōu)化的核心技巧。無(wú)論你是剛?cè)腴T(mén)的運(yùn)維新手,還是有一定經(jīng)驗(yàn)的工程師,這篇文章都將為你提供實(shí)用的解決方案。
    的頭像 發(fā)表于 09-08 09:34 ?972次閱讀

    數(shù)據(jù)庫(kù)性能瓶頸分析與SQL優(yōu)化實(shí)戰(zhàn)案例

    作為一名在一線摸爬滾打8年的運(yùn)維工程師,我見(jiàn)過(guò)太多因?yàn)?b class='flag-5'>數(shù)據(jù)庫(kù)性能問(wèn)題而半夜被叫醒的場(chǎng)景。今天分享幾個(gè)真實(shí)的優(yōu)化案例,希望能幫你避開(kāi)這些坑。
    的頭像 發(fā)表于 08-27 14:31 ?579次閱讀

    數(shù)據(jù)庫(kù)性能優(yōu)化指南

    作為一名在大廠摸爬滾打多年的運(yùn)維老兵,我見(jiàn)過(guò)太多因?yàn)?b class='flag-5'>數(shù)據(jù)庫(kù)性能問(wèn)題導(dǎo)致的生產(chǎn)事故。今天分享一套完整的數(shù)據(jù)庫(kù)優(yōu)化方法論,從SQL層面到硬件配置,幫你徹底解決性能瓶頸!
    的頭像 發(fā)表于 08-18 11:21 ?737次閱讀

    數(shù)據(jù)庫(kù)數(shù)據(jù)恢復(fù)—服務(wù)器異常斷電導(dǎo)致Oracle數(shù)據(jù)庫(kù)故障的數(shù)據(jù)恢復(fù)案例

    Oracle數(shù)據(jù)庫(kù)故障: 某公司一臺(tái)服務(wù)器上部署Oracle數(shù)據(jù)庫(kù)。服務(wù)器意外斷電導(dǎo)致數(shù)據(jù)庫(kù)報(bào)錯(cuò),報(bào)錯(cuò)內(nèi)容為“system01.dbf需要更多的恢復(fù)來(lái)保持一致性”。該Oracle數(shù)據(jù)庫(kù)
    的頭像 發(fā)表于 07-24 11:12 ?630次閱讀
    <b class='flag-5'>數(shù)據(jù)庫(kù)</b><b class='flag-5'>數(shù)據(jù)</b>恢復(fù)—服務(wù)器異常斷電導(dǎo)致Oracle<b class='flag-5'>數(shù)據(jù)庫(kù)</b>故障的<b class='flag-5'>數(shù)據(jù)</b>恢復(fù)案例

    企業(yè)級(jí)MySQL數(shù)據(jù)庫(kù)管理指南

    在當(dāng)今數(shù)字化時(shí)代,MySQL作為全球最受歡迎的開(kāi)源關(guān)系型數(shù)據(jù)庫(kù),承載著企業(yè)核心業(yè)務(wù)數(shù)據(jù)的存儲(chǔ)與處理。作為數(shù)據(jù)庫(kù)管理員(DBA),掌握MySQL的企業(yè)級(jí)部署、優(yōu)化、維護(hù)技能至關(guān)重要。本文
    的頭像 發(fā)表于 07-09 09:50 ?714次閱讀

    數(shù)據(jù)庫(kù)數(shù)據(jù)恢復(fù)—MongoDB數(shù)據(jù)庫(kù)文件丟失的數(shù)據(jù)恢復(fù)案例

    MongoDB數(shù)據(jù)庫(kù)數(shù)據(jù)恢復(fù)環(huán)境: 一臺(tái)操作系統(tǒng)為Windows Server的虛擬機(jī)上部署MongoDB數(shù)據(jù)庫(kù)。 MongoDB數(shù)據(jù)庫(kù)故障: 工作人員在MongoDB服務(wù)仍
    的頭像 發(fā)表于 07-01 11:13 ?634次閱讀
    <b class='flag-5'>數(shù)據(jù)庫(kù)</b><b class='flag-5'>數(shù)據(jù)</b>恢復(fù)—MongoDB<b class='flag-5'>數(shù)據(jù)庫(kù)</b>文件丟失的<b class='flag-5'>數(shù)據(jù)</b>恢復(fù)案例

    數(shù)據(jù)庫(kù)數(shù)據(jù)恢復(fù)—SQL Server數(shù)據(jù)庫(kù)被加密如何恢復(fù)數(shù)據(jù)

    SQL Server數(shù)據(jù)庫(kù)故障: SQL Server數(shù)據(jù)庫(kù)被加密,無(wú)法使用。 數(shù)據(jù)庫(kù)MDF、LDF、log日志文件名字被篡改。
    的頭像 發(fā)表于 06-25 13:54 ?667次閱讀
    <b class='flag-5'>數(shù)據(jù)庫(kù)</b><b class='flag-5'>數(shù)據(jù)</b>恢復(fù)—SQL Server<b class='flag-5'>數(shù)據(jù)庫(kù)</b>被加密如何恢復(fù)<b class='flag-5'>數(shù)據(jù)</b>?

    oracle數(shù)據(jù)恢復(fù)—oracle數(shù)據(jù)庫(kù)誤執(zhí)行錯(cuò)誤truncate命令如何恢復(fù)數(shù)據(jù)?

    oracle數(shù)據(jù)庫(kù)誤執(zhí)行truncate命令導(dǎo)致數(shù)據(jù)丟失是一種常見(jiàn)情況。通常情況下,oracle數(shù)據(jù)庫(kù)誤操作刪除數(shù)據(jù)只需要通過(guò)備份恢復(fù)數(shù)據(jù)
    的頭像 發(fā)表于 06-05 16:01 ?1021次閱讀
    oracle<b class='flag-5'>數(shù)據(jù)</b>恢復(fù)—oracle<b class='flag-5'>數(shù)據(jù)庫(kù)</b>誤執(zhí)行錯(cuò)誤truncate命令如何恢復(fù)<b class='flag-5'>數(shù)據(jù)</b>?

    SQLSERVER數(shù)據(jù)庫(kù)是什么

    SQL Server 是由微軟公司開(kāi)發(fā)的一款 關(guān)系型數(shù)據(jù)庫(kù)管理系統(tǒng)(RDBMS) ,用于存儲(chǔ)、管理和檢索結(jié)構(gòu)化數(shù)據(jù)。它是企業(yè)級(jí)應(yīng)用中廣泛使用的數(shù)據(jù)庫(kù)解決方案之一,尤其適用于Windows平臺(tái),但也
    的頭像 發(fā)表于 05-26 09:19 ?1166次閱讀

    MySQL數(shù)據(jù)庫(kù)是什么

    MySQL數(shù)據(jù)庫(kù)是一種 開(kāi)源的關(guān)系型數(shù)據(jù)庫(kù)管理系統(tǒng)(RDBMS) ,由瑞典MySQL AB公司開(kāi)發(fā),后被Oracle公司收購(gòu)。它通過(guò)結(jié)構(gòu)化查詢(xún)語(yǔ)言(SQL)進(jìn)行數(shù)據(jù)存儲(chǔ)、管理和操作,廣泛應(yīng)用于Web
    的頭像 發(fā)表于 05-23 09:18 ?1188次閱讀

    數(shù)據(jù)庫(kù)數(shù)據(jù)恢復(fù)——MongoDB數(shù)據(jù)庫(kù)文件拷貝后服務(wù)無(wú)法啟動(dòng)的數(shù)據(jù)恢復(fù)

    MongoDB數(shù)據(jù)庫(kù)數(shù)據(jù)恢復(fù)環(huán)境: 一臺(tái)Windows Server操作系統(tǒng)虛擬機(jī)上部署MongoDB數(shù)據(jù)庫(kù)。 MongoDB數(shù)據(jù)庫(kù)故障: 管理員在未關(guān)閉MongoDB服務(wù)的
    的頭像 發(fā)表于 04-09 11:34 ?863次閱讀
    <b class='flag-5'>數(shù)據(jù)庫(kù)</b><b class='flag-5'>數(shù)據(jù)</b>恢復(fù)——MongoDB<b class='flag-5'>數(shù)據(jù)庫(kù)</b>文件拷貝后服務(wù)無(wú)法啟動(dòng)的<b class='flag-5'>數(shù)據(jù)</b>恢復(fù)

    云服務(wù)器數(shù)據(jù)庫(kù)購(gòu)買(mǎi)流程匯總,小白也能輕松上手!

    云服務(wù)器數(shù)據(jù)庫(kù)購(gòu)買(mǎi)流程通常包括需求評(píng)估、供應(yīng)商選擇、配置與定價(jià)、注冊(cè)賬號(hào)、填寫(xiě)訂單信息、支付費(fèi)用以及后續(xù)的設(shè)置與配置等步驟。其核心邏輯在于通過(guò)精準(zhǔn)匹配業(yè)務(wù)需求(如性能、存儲(chǔ)、合規(guī)性)與云服務(wù)能力,完成資源選型、策略配置及成本優(yōu)化
    的頭像 發(fā)表于 03-05 10:58 ?708次閱讀