欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MYSQL數(shù)據(jù)庫表結(jié)構(gòu)優(yōu)化方法詳解

 更新時(shí)間:2019年08月09日 10:44:28   作者:人生如初見_張默  
這篇文章主要介紹了MYSQL數(shù)據(jù)庫表結(jié)構(gòu)優(yōu)化方法,總結(jié)分析了mysql針對表結(jié)構(gòu)優(yōu)化的數(shù)據(jù)類型選擇、范式化操作、表的拆分等相關(guān)使用技巧,需要的朋友可以參考下

本文實(shí)例講述了MYSQL數(shù)據(jù)庫表結(jié)構(gòu)優(yōu)化方法。分享給大家供大家參考,具體如下:

 選擇合適的數(shù)據(jù)類型

    1、使用可以存下你的數(shù)據(jù)的最小的數(shù)據(jù)類型

    2、使用簡單的數(shù)據(jù)類型。Int要比varchar類型在mysql處理上簡單

    3、盡可能的使用not null定義字段

    4、盡量少用text類型,非用不可時(shí)最好考慮分表

使用int來存儲日期時(shí)間,利用FROM_UNIXTIME()【將int類型時(shí)間戳轉(zhuǎn)換成日期時(shí)間格式】,UNIX_TIMESTAMP()【將日期時(shí)間格式轉(zhuǎn)換成int類型】兩個(gè)函數(shù)進(jìn)行轉(zhuǎn)換

使用bigint來存儲IP地址,利用INET_ATON()【將IP格式轉(zhuǎn)換成int】,INET_NTOA()【將int格式轉(zhuǎn)換成正常IP格式】兩個(gè)函數(shù)進(jìn)行轉(zhuǎn)換

表的范式化和反范式化

范式化是指數(shù)據(jù)庫設(shè)計(jì)的規(guī)范,目前的范式化一般指第三設(shè)計(jì)范式,也就是要求數(shù)據(jù)表中不存在非關(guān)鍵字段對任意候選關(guān)鍵字段

的傳遞函數(shù)依賴則符合第三范式。

不符合第三范式要求的表存在下列問題:

    1、數(shù)據(jù)冗余:(分類,分類描述)對于每一個(gè)商品都會進(jìn)行記錄

    2、數(shù)據(jù)的插入/更新/刪除異常

范式化操作:

反范式化是指為了查詢效率和考慮把原本符合第三范式的表適當(dāng)?shù)脑黾尤哂?,以達(dá)到優(yōu)化查詢效率的目的,反范式化是一種以空間來換取時(shí)間的操作。

例:

   

對表進(jìn)行反范式化

反范式化查詢訂單信息:

表的垂直拆分

   垂直拆分就是把原來 很多列的表拆分成多個(gè)表,這就解決了表的寬度問題。通常垂直拆分可以按以下原則進(jìn)行:

        1、把不常用的字段單獨(dú)存放到一個(gè)表中。

        2、把大字段獨(dú)立存放到一個(gè)表中。

        3、把經(jīng)常一起使用的字段放到一起。

水平拆分

    表的水平拆分是為了解決單表的數(shù)據(jù)量過大問題,水平拆分的表每個(gè)表的結(jié)構(gòu)都是完全一致的

 常用的水平拆分方法:

    1、對customer_id進(jìn)行hash運(yùn)算,如果要拆分成5個(gè)表則使用mod(custoneer_id,5)取出0-4個(gè)值

    2、針對不同的hashID把數(shù)據(jù)存到不同的表中

更多關(guān)于MySQL相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《MySQL查詢技巧大全》、《MySQL常用函數(shù)大匯總》、《MySQL日志操作技巧大全》、《MySQL事務(wù)操作技巧匯總》、《MySQL存儲過程技巧大全》及《MySQL數(shù)據(jù)庫鎖相關(guān)技巧匯總

希望本文所述對大家MySQL數(shù)據(jù)庫計(jì)有所幫助。

相關(guān)文章

  • MySQL之容災(zāi)方案解讀

    MySQL之容災(zāi)方案解讀

    這篇文章主要介紹了MySQL之容災(zāi)方案,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • MySQL配置SSL主從復(fù)制

    MySQL配置SSL主從復(fù)制

    本文給大家分享的是如何給mysql配置SSL主從復(fù)制的具體方法,分別給出了5.6和5.7兩個(gè)版本的實(shí)例,希望大家能夠喜歡
    2019-01-01
  • SQL語句單引號與雙引號的使用方法

    SQL語句單引號與雙引號的使用方法

    這篇文章主要介紹了SQL語句中單引號、雙引號的使用方法,分別講述,雖然說的是Insert語句,?但是Select、Update、Delete語句都是一樣的,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-03-03
  • MySQL8.0無法啟動3534的解決方法

    MySQL8.0無法啟動3534的解決方法

    本文主要是記錄一下自己使用MySQL的一次踩坑經(jīng)歷,我的MySQL安裝好后,使用一周后的同一時(shí)間必定報(bào)連接失敗,然后查找發(fā)現(xiàn)是MySQL本地服務(wù)沒有啟動,下面就詳細(xì)的介紹一下
    2021-06-06
  • MySQL數(shù)據(jù)庫的約束使用實(shí)例

    MySQL數(shù)據(jù)庫的約束使用實(shí)例

    約束是用來限制表中的數(shù)據(jù)長什么樣子的,即什么樣的數(shù)據(jù)可以插入到表中,什么樣的數(shù)據(jù)插入不到表中,下面這篇文章主要給大家介紹了關(guān)于如何通過一文理解MySQL數(shù)據(jù)庫的約束與表的設(shè)計(jì)的相關(guān)資料,需要的朋友可以參考下
    2022-12-12
  • mysql觸發(fā)器中監(jiān)控字段的改變方式

    mysql觸發(fā)器中監(jiān)控字段的改變方式

    這篇文章主要介紹了mysql觸發(fā)器中監(jiān)控字段的改變方式,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-08-08
  • 詳解Mysql 30條軍規(guī)

    詳解Mysql 30條軍規(guī)

    這篇文章主要介紹了詳解Mysql 30條軍規(guī),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-08-08
  • MySQL關(guān)閉密碼強(qiáng)度驗(yàn)證功能

    MySQL關(guān)閉密碼強(qiáng)度驗(yàn)證功能

    本文通過實(shí)例代碼給大家介紹了mysql關(guān)閉密碼強(qiáng)度驗(yàn)證功能,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友參考下吧
    2017-06-06
  • 解決net start mysql--服務(wù)無法啟動 服務(wù)沒有報(bào)告任何錯(cuò)誤問題

    解決net start mysql--服務(wù)無法啟動 服務(wù)沒有報(bào)告任何錯(cuò)誤問題

    這篇文章主要介紹了解決net start mysql--服務(wù)無法啟動 服務(wù)沒有報(bào)告任何錯(cuò)誤問題,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-12-12
  • Mysql中二進(jìn)制日志操作方法說明

    Mysql中二進(jìn)制日志操作方法說明

    這篇文章主要介紹了Mysql中二進(jìn)制日志操作方法,二進(jìn)制日志中以“事件”的形式記錄了數(shù)據(jù)庫中數(shù)據(jù)的變化情況,對于MySQL數(shù)據(jù)庫的災(zāi)難恢復(fù)起著重要的作用
    2023-03-03

最新評論