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

SQL筆記之數(shù)據(jù)庫結(jié)構(gòu)優(yōu)化方式

 更新時間:2024年01月24日 09:52:58   作者:Little.M_  
這篇文章主要介紹了SQL筆記之數(shù)據(jù)庫結(jié)構(gòu)優(yōu)化方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教

SQL筆記之數(shù)據(jù)庫結(jié)構(gòu)優(yōu)化

1. 拆分表(冷熱數(shù)據(jù)分離)

不常用的數(shù)據(jù)為冷數(shù)據(jù),反之則為熱數(shù)據(jù)。

如果一個表中的數(shù)據(jù)存在明顯的使用頻率差異,那么可以將冷熱數(shù)據(jù)分離。

通過這種分解可以提高表的查詢效率。

對于字段很多且有些字段使用不頻繁的表,可以通過這種分解的方式來優(yōu)化數(shù)據(jù)庫的性能。

例如:

會員members表存儲會員登錄認證信息,該表中有很多字段,如id、姓名、密碼、地址、電 話、個人描述字段。

其中地址、電話、個人描述等字段并不常用,可以將這些不常用的字段分解出另一 個表。

2. 增加中間表

假如當前有兩個表,學生信息表包含id、學號、姓名、年齡和班號,班級表包含id、班級名、地址、班長。

若現(xiàn)在有一個模塊需要經(jīng)常查詢帶有學生名稱(name)、學生所在班級名稱(className)、學生班級班 長(monitor)的學生信息。

根據(jù)這種情況可以創(chuàng)建一個 temp_student 表。temp_student表中存儲學生名稱(stu_name)、學生所在班級名稱(className)和學生班級班長(monitor)信息。

以后,可以直接從temp_student表中查詢學生名稱、班級名稱和班級班長,而不用每次都進行聯(lián)合查 詢。這樣可以提高數(shù)據(jù)庫的查詢速度。

3. 增加冗余字段

設(shè)計數(shù)據(jù)庫表時應盡量遵循范式理論的規(guī)約,盡可能減少冗余字段,讓數(shù)據(jù)庫設(shè)計看起來精致、優(yōu)雅。 但是,合理地加入冗余字段可以提高查詢速度。

表的規(guī)范化程度越高,表與表之間的關(guān)系就越多,需要連接查詢的情況也就越多。

尤其在數(shù)據(jù)量大,而 且需要頻繁進行連接的時候,為了提升效率,我們也可以考慮增加冗余字段來減少連接。

4. 優(yōu)化數(shù)據(jù)類型

(1)對整數(shù)類型數(shù)據(jù)進行優(yōu)化。

遇到整數(shù)類型的字段可以用 INT 型 。這樣做的理由是,INT 型數(shù)據(jù)有足夠大的取值范圍,不用擔心數(shù) 據(jù)超出取值范圍的問題。

剛開始做項目的時候,首先要保證系統(tǒng)的穩(wěn)定性,這樣設(shè)計字段類型是可以 的。

但在數(shù)據(jù)量很大的時候,數(shù)據(jù)類型的定義,在很大程度上會影響到系統(tǒng)整體的執(zhí)行效率。

對于 非負型 的數(shù)據(jù)(如自增ID、整型IP)來說,要優(yōu)先使用無符號整型 UNSIGNED 來存儲。

因為無符號 相對于有符號,同樣的字節(jié)數(shù),存儲的數(shù)值范圍更大。

如tinyint有符號為-128-127,無符號為0-255,多出一倍的存儲空間。

(2)既可以使用文本類型也可以使用整數(shù)類型的字段,要選擇使用整數(shù)類型。

跟文本類型數(shù)據(jù)相比,大整數(shù)往往占用更少的存儲空間 ,因此,在存取和比對的時候,可以占用更少的 內(nèi)存空間。

所以,在二者皆可用的情況下,盡量使用整數(shù)類型,這樣可以提高查詢的效率。

如:將IP地 址轉(zhuǎn)換成整型數(shù)據(jù)。

(3)避免使用TEXT、BLOB數(shù)據(jù)類型

(4)避免使用ENUM類型

修改ENUM值需要使用ALTER語句。

ENUM類型的ORDER BY 操作效率低,需要額外操作。使用TINYINT來代替ENUM類型。

(5)使用TIMESTAMP存儲時間

TIMESTAMP存儲的時間范圍1970-01-01 00:00:01 ~ 2038-01_19-03:14:07。

TIMESTAMP使用4字節(jié),DATETIME使用8個字節(jié),同時TIMESTAMP具有自動賦值以及自動更新的特性。

(6)用DECIMAL代替FLOAT和DOUBLE存儲精確浮點數(shù)

  • 非精準浮點: float, double
  • 精準浮點:decimal

Decimal類型為精準浮點數(shù),在計算時不會丟失精度,尤其是財務相關(guān)的金融類數(shù)據(jù)。

占用空間由定義的寬度決定,每4個字節(jié)可以存儲9位數(shù)字,并且小數(shù)點要占用一個字節(jié)。

可用于存儲比bigint更大的整型數(shù)據(jù)。

總之,遇到數(shù)據(jù)量大的項目時,一定要在充分了解業(yè)務需求的前提下,合理優(yōu)化數(shù)據(jù)類型,這樣才能充 分發(fā)揮資源的效率,使系統(tǒng)達到最優(yōu)。

5. 優(yōu)化插入記錄的速度

插入記錄時,影響插入速度的主要是索引、唯一性校驗、一次插入記錄條數(shù)等。根據(jù)這些情況可以分別進行優(yōu)化。

(1)MyISAM引擎的表:

  • ① 禁用索引
  • ② 禁用唯一性檢查
  • ③ 使用批量插入

插入多條記錄時,可以使用一條INSERT語句插入一條數(shù)據(jù),也可以使用一條INSERT語句插入多條數(shù)據(jù)。

插入一條記錄的INSERT語句情形如下:

insert into student values(1,'zhangsan',18,1);
insert into student values(2,'lisi',17,1);
insert into student values(3,'wangwu',17,1);
insert into student values(4,'zhaoliu',19,1);

使用一條INSERT語句插入多條記錄的情形如下:

insert into student values
(1,'zhangsan',18,1),
(2,'lisi',17,1),
(3,'wangwu',17,1),
(4,'zhaoliu',19,1);

第2種情形的插入速度要比第1種情形快。

  • ④ 使用LOAD DATA INFILE 批量導入

當需要批量導入數(shù)據(jù)時,如果能用LOAD DATA INFILE語句,就盡量使用。

因為LOAD DATA INFILE語句導入數(shù)據(jù)的速度比INSERT語句塊。

(2) InnoDB引擎的表:

  • ① 禁用唯一性檢查

插入數(shù)據(jù)之前執(zhí)行set unique_checks=0來禁止對唯一索引的檢查,數(shù)據(jù)導入完成之后再運行set unique_check=1。

這個和MyISAM引擎的使用方法一樣。

  • ② 禁用外鍵檢查
  • ③ 禁止自動提交

6. 使用非空約束

總結(jié)

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • mysql存儲過程多層游標循環(huán)嵌套的寫法分享

    mysql存儲過程多層游標循環(huán)嵌套的寫法分享

    這篇文章主要介紹了mysql存儲過程多層游標循環(huán)嵌套的寫法,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-07-07
  • MySQL中EXPLAIN的/基本使用及字段詳解

    MySQL中EXPLAIN的/基本使用及字段詳解

    EXPLAIN命令是MySQL中用于解析SQL查詢語句的工具,幫助開發(fā)者理解MySQL如何執(zhí)行SQL語句,通過EXPLAIN可以查看SQL執(zhí)行的詳細信息,如表的讀取順序、使用的索引、數(shù)據(jù)讀取操作的類型等,這篇文章主要介紹了MySQL中EXPLAIN的/基本使用及字段詳解,需要的朋友可以參考下
    2024-09-09
  • 一文搞懂什么是MySQL前綴索引

    一文搞懂什么是MySQL前綴索引

    所謂前綴索引,說白了就是對文本的前幾個字符建立索引,有點類似于?Oracle?中對字段使用?Left?函數(shù)來建立函數(shù)索引,只不過?MySQL?的這個前綴索引在查詢時是內(nèi)部自動完成匹配的。本文將通過示例詳細聊聊前綴索引,需要的可以參考一下
    2022-09-09
  • MYSQL數(shù)據(jù)庫使用UTF-8中文編碼亂碼的解決辦法

    MYSQL數(shù)據(jù)庫使用UTF-8中文編碼亂碼的解決辦法

    這篇文章主要介紹了MYSQL數(shù)據(jù)庫使用UTF-8中文編碼亂碼的解決辦法,需要的朋友可以參考下
    2015-10-10
  • MySql中的IFNULL、NULLIF和ISNULL用法詳解

    MySql中的IFNULL、NULLIF和ISNULL用法詳解

    本文主要介紹了MySql中的IFNULL、NULLIF和ISNULL用法詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-03-03
  • 如何提高MySQL Limit查詢性能的方法詳解

    如何提高MySQL Limit查詢性能的方法詳解

    今天小編就為大家分享一篇關(guān)于如何提高MySQL Limit查詢性能的方法詳解,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-03-03
  • mysql 定時任務的實現(xiàn)與使用方法示例

    mysql 定時任務的實現(xiàn)與使用方法示例

    這篇文章主要介紹了mysql 定時任務的實現(xiàn)與使用方法,結(jié)合實例形式分析了MySQL定時任務的相關(guān)原理、創(chuàng)建及使用方法,需要的朋友可以參考下
    2019-11-11
  • MySQL復合查詢和內(nèi)外連接的操作代碼

    MySQL復合查詢和內(nèi)外連接的操作代碼

    實際開發(fā)中往往數(shù)據(jù)來自不同的表,所以需要多表查詢,但是可以將多張表做笛卡爾積后的表當做是一張表,也就是單表查詢,這篇文章主要介紹了MySQL復合查詢和內(nèi)外連接,需要的朋友可以參考下
    2022-09-09
  • mysql的日期和時間函數(shù)

    mysql的日期和時間函數(shù)

    mysql的日期和時間函數(shù) 這里是一個使用日期函數(shù)的例子。
    2010-11-11
  • mysql CPU高負載問題排查

    mysql CPU高負載問題排查

    這篇文章主要介紹了mysql CPU高負載問題排查的相關(guān)資料,幫助大家更好的理解和使用MySQL,維護數(shù)據(jù)庫,感興趣的朋友可以了解下
    2020-11-11

最新評論