偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

關(guān)系型數(shù)據(jù)庫(kù)性能優(yōu)化總結(jié)

數(shù)據(jù)庫(kù)
今天我們要討論的是關(guān)系型數(shù)據(jù)庫(kù)性能優(yōu)化的問(wèn)題,平時(shí)我們也最好要遵守一定的規(guī)則,希望對(duì)大家有所幫助。

對(duì)于web應(yīng)用開發(fā),多數(shù)性能瓶頸均出現(xiàn)在數(shù)據(jù)庫(kù)上,除了采用分布式架構(gòu)或云處理(大公司基本上都是),更重要的是平時(shí)程序設(shè)計(jì)時(shí)要遵照一些規(guī)則,從根本上提高系統(tǒng)的性能,以下總結(jié)了一些常用的規(guī)則方法,僅供參考,歡迎跟帖補(bǔ)充。。。

1、 把數(shù)據(jù)、日志、索引放到不同的I/O設(shè)備上,增加讀取速度。數(shù)據(jù)量(尺寸)越大,提高I/O越重要。

2、 縱向、橫向分割表,減少表的尺寸,如:可以把大數(shù)據(jù)量的字段拆分表。

3、 根據(jù)查詢條件,建立索引,優(yōu)化索引、優(yōu)化訪問(wèn)方式,限制結(jié)果集的數(shù)據(jù)量。注意填充因子要適當(dāng)(最好是使用默認(rèn)值0)。索引應(yīng)該盡量小,盡量使用字節(jié)數(shù)小的列建索引,不要對(duì)有限的幾個(gè)值的列建單一索引。

4、 用OR的字句可以分解成多個(gè)查詢,并且通過(guò)UNION鏈接多個(gè)查詢。它們的速度只與是否使用索引有關(guān),如果查詢需要用到聯(lián)合索引,用UNION all執(zhí)行的效率更高。

5、 在查詢SELECT語(yǔ)句中用WHERE子句限制返回的行數(shù),避免表掃描。如果返回不必要的數(shù)據(jù),則浪費(fèi)了服務(wù)器的I/O資源,加重了網(wǎng)絡(luò)的負(fù)擔(dān),降低了性能。如果表很大,在表掃描期間將表鎖住,禁止其他的聯(lián)結(jié)訪問(wèn)表,后果很嚴(yán)重。

6、 注意使用DISTINCT,在沒(méi)有必要時(shí)不要用,它同UNION一樣會(huì)使查詢變慢。

7、 在IN后面值的列表中,將出現(xiàn)最頻繁的值放在最前面,出現(xiàn)最少的放在最后面,減少判斷的次數(shù)。

8、 一般在GROUP BY和HAVING子句之前就能剔除多余的行,所以盡量不要用它們來(lái)做剔除行的工作,也就是說(shuō)盡可能在WHERE中過(guò)濾數(shù)據(jù)。

9、 盡量將數(shù)據(jù)的處理工作放在服務(wù)器上,減少網(wǎng)絡(luò)的開銷,如使用存儲(chǔ)過(guò)程。存儲(chǔ)過(guò)程是編譯、優(yōu)化過(guò),并且被組織到一個(gè)執(zhí)行規(guī)劃里,且存儲(chǔ)在數(shù)據(jù)庫(kù)中的SQL語(yǔ)句(存儲(chǔ)過(guò)程是數(shù)據(jù)庫(kù)服務(wù)器端的一段程序),是控制流語(yǔ)言的集合,速度當(dāng)然快。

10、 不要在一句話里再三地使用相同的函數(shù),浪費(fèi)資源,將結(jié)果放在變量里再調(diào)用更快。

11、 針對(duì)大量只讀查詢操作進(jìn)行優(yōu)化的方法:

1)數(shù)據(jù)量小的數(shù)據(jù),可以考慮不存儲(chǔ)在數(shù)據(jù)庫(kù)中,而是通過(guò)程序常量的方式解決。

2)需要存儲(chǔ)在數(shù)據(jù)庫(kù)中的數(shù)據(jù),可以考慮采用物化視圖(索引視圖)。當(dāng)DBA在視圖上創(chuàng)建索引時(shí),這個(gè)視圖就被物化(執(zhí)行)了,并且結(jié)果集被永久地保存在唯一索引中,保存方式與一個(gè)有聚簇索引的表的保存方式相同。物化視圖減除了為引用視圖的查詢動(dòng)態(tài)建立結(jié)果集的開銷,優(yōu)化人員可以在查詢中使用視圖索引,而不需要在FROM子句中直接指定視圖。

3)數(shù)據(jù)存儲(chǔ)時(shí)可以考慮適當(dāng)?shù)臄?shù)據(jù)冗余,以減少數(shù)據(jù)庫(kù)表之間的鏈接操作,提高查詢效率。

4)針對(duì)數(shù)據(jù)的特點(diǎn),采取特定的索引類型。例如,位圖索引等。

12、 對(duì)于SQL語(yǔ)句書寫時(shí)的一些建議:

1)寫語(yǔ)句時(shí)能夠確定數(shù)據(jù)庫(kù)對(duì)象所有者的,盡可能把所有者帶上,如:

  1. SELECT * FROM dbo.Users 

2)存儲(chǔ)過(guò)程中,參數(shù)定義最好放在最前面,盡可能一次定義,如:

 

  1. DECLARE @USER_ID INT 
  2.    ,@USER_NAME   VARCHAR(50)  
  3.    ,@PASSWORD VARCHAR(50) 

3)為參數(shù)賦值時(shí),盡可能一次賦值,如:

  1. SELECT @USER_ID = 1001  
  2.    ,@USER_NAME = 'xiaojun.liu' 

4)盡量少用游標(biāo)

原文鏈接:http://www.cnblogs.com/liuxiaojun/archive/2010/12/09/database_performance_optimization.html

【編輯推薦】

  1. IBM DB2中提高并發(fā)度的3個(gè)好用方案介紹
  2. MySQL百萬(wàn)級(jí)高并發(fā)網(wǎng)站實(shí)戰(zhàn)攻略
  3. PHP將數(shù)據(jù)從Oracle向MySQL數(shù)據(jù)遷移實(shí)例

 

責(zé)任編輯:彭凡 來(lái)源: 博客園
相關(guān)推薦

2018-07-18 09:16:39

關(guān)系型非關(guān)系型數(shù)據(jù)庫(kù)

2021-09-06 10:24:12

鴻蒙HarmonyOS應(yīng)用

2022-06-13 08:30:01

數(shù)據(jù)庫(kù)管理系統(tǒng)

2019-08-16 09:12:59

數(shù)據(jù)庫(kù)PostgreSQL Oracle

2013-09-17 10:32:08

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

2017-03-17 14:44:04

關(guān)系型數(shù)據(jù)庫(kù)原理

2021-01-31 17:50:41

數(shù)據(jù)庫(kù)查詢程序員

2011-05-20 10:30:20

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

2011-05-18 09:39:19

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

2023-07-12 08:55:16

PawSQL數(shù)據(jù)庫(kù)

2021-01-26 13:31:48

數(shù)據(jù)庫(kù)關(guān)系型數(shù)據(jù)庫(kù)冗余

2023-05-22 16:10:51

動(dòng)態(tài)共享包數(shù)據(jù)庫(kù)

2023-05-20 08:11:55

2021-07-28 14:40:57

鴻蒙HarmonyOS應(yīng)用

2022-07-27 08:32:01

數(shù)據(jù)庫(kù)MySQL

2016-08-23 14:25:19

MySQL約束數(shù)據(jù)庫(kù)

2022-12-27 08:38:45

關(guān)系型數(shù)據(jù)庫(kù)設(shè)計(jì)

2013-04-26 16:18:29

大數(shù)據(jù)全球技術(shù)峰會(huì)

2014-07-18 09:33:53

數(shù)據(jù)庫(kù)數(shù)據(jù)庫(kù)優(yōu)化

2010-05-10 15:50:39

Oracle數(shù)據(jù)庫(kù)性能
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)