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

數(shù)據(jù)庫查詢優(yōu)化(主從表的設(shè)計)

 更新時間:2013年08月04日 14:42:21   作者:  
寫過許多的數(shù)據(jù)庫查詢語句,面對過許多的問題,也在磕磕碰碰中學(xué)到了很多東西。昨天在看系統(tǒng)數(shù)據(jù)庫設(shè)計與SQL代碼時,突然“發(fā)現(xiàn)”了許多平常不屑看到的問題,于是就萌生了把它提出來思考的念頭

舉一個例子,我現(xiàn)在有一些新聞信息,它包括這些字段;新聞ID,新聞Name,新聞ShortIntro,新聞Detail,新聞PublishTime。我現(xiàn)在要把它存放在數(shù)據(jù)庫中,然后從數(shù)據(jù)庫中將其取出來放在GridView中分頁顯示。

我現(xiàn)在就以一種我所見過的常見的思維方式來一步一步模擬這個實現(xiàn)過程。

第一步:建立新聞數(shù)據(jù)表。

在這一步,很多人都會直接建一張News表,里面包括了上面說的那些字段。

第二步:查詢數(shù)據(jù)。

寫一個方法,把News表中滿足查詢條件的數(shù)據(jù)取出來放在DataSet(DataTable)中,作為數(shù)據(jù)源。

第三步:綁定到GridView。

設(shè)置GridView的分頁屬性,將上面查詢得到的數(shù)據(jù)源綁定到GridView,實現(xiàn)數(shù)據(jù)在GridView中的分頁顯示。

上面就是我們常見的做法了。

我的做法會是這樣:

第一步:建立新聞數(shù)據(jù)主-從表

我們在系統(tǒng)開發(fā)過程中會發(fā)現(xiàn),其實在一條的完整的數(shù)據(jù)信息中,其實很多時候,很多列表項并不會用到。我們分析News信息,我們可以初步的把ID,Name,ShortIntro,PublishTime作為主要信息,我們將這些信息集中起來,新建一張表News(ID,Name,ShortIntro,PublishTime),另外一個字段Detail放在另一張從表中,新建一張表NewsDetail(ID,Detail,NewsID)。這樣做有什么好處呢,首先我們降低了表的“重量”。我們將最重要,最常用的信息簡化出來放在一個主表中,這樣在使用過程中,我們只需要從這張住表中獲取我們所需的數(shù)據(jù)就可以了,而不需要像第一種方法一樣遍歷所有字段,這減少了數(shù)據(jù)庫查詢的時間,提高了性能。主-從表建立的原則是,將最重要的,最常用的分離出來作為主表,將那些描述性的,內(nèi)容龐大的作為從表。

第二步:編寫適合的SQL語句。

我們應(yīng)該為不同的功能實現(xiàn)編寫適合的SQL語句。上面那種方法中,用一個方法查詢出了所有的數(shù)據(jù)信息,這是滿足所有場合的數(shù)據(jù)要求的。但是,我們并不需要這么多的數(shù)據(jù)內(nèi)容,多余的數(shù)據(jù)內(nèi)容耗費(fèi)了我們大量的時間和空間。我們往往只需要其中的部分內(nèi)容,比如說主要信息。這也印證了為什么我們上面要建立主-從表。我們在建立了主-從表之后,為滿足各種場合,可以編寫以下幾種方法:GetNews(int? ID, string Name)//從主表中查詢滿足條件的數(shù)據(jù),GetNewsDetail(int? ID, string Name)//從主表和從表中查詢滿足條件的數(shù)據(jù)。第一種方法提供了新聞主要信息,第二種方法提供了全面的信息,這兩種方法基本上就能滿足所有場景且不會帶來過多的數(shù)據(jù)冗余。這里還要指出一點(diǎn),有些人喜歡這么寫GetNewsByID(int? ID ),GetNewsByName(string Name),這樣寫是很靈活,很有針對性,但是這樣寫完全沒必要。

第三步:分頁綁定。

上面那種方法是一次性取出所有數(shù)據(jù)給GridView,讓控件自己去分頁,這樣做方便省事。但是會有幾個問題:

(1)數(shù)據(jù)量大。因為是一次性取出所有滿足條件的數(shù)據(jù),所以數(shù)據(jù)量比較大,而這些數(shù)據(jù)是都需要放在內(nèi)存中的,所以會影響系統(tǒng)性能。而且在初次載入時會有些卡,給人的感覺是系統(tǒng)加載不平順。

(2)我們并不需要這么多數(shù)據(jù)。為什么我要這么說呢?研究用戶的使用習(xí)慣我們會發(fā)現(xiàn),用戶大多數(shù)情況下并不會逐頁的去瀏覽數(shù)據(jù),用戶關(guān)注的往往是前幾頁的前幾條。所以取出來的數(shù)據(jù)很多時候并沒有被用戶查看。

所以在這里,使用分頁查詢的方式是更加合適的。每次只從數(shù)據(jù)庫里面查詢一頁數(shù)據(jù),這樣系統(tǒng)負(fù)載小,頁面載入平順,而且完全能夠滿足用戶的使用要求。有些人會問,你這樣做不是會增加數(shù)據(jù)庫IO次數(shù),我想說的是,一次性獲取大量冗余數(shù)據(jù),并要承擔(dān)冗余所帶來的持久影響與這些比理論上增加的IO次數(shù)(用戶并不會逐頁查看,也就并不會產(chǎn)生那么多次分頁查詢)要小得多的訪問相比,分頁查詢具有不可否定的優(yōu)勢。

相關(guān)文章

  • SQL中一些小巧但常用的關(guān)鍵字小結(jié)

    SQL中一些小巧但常用的關(guān)鍵字小結(jié)

    這篇文章主要給大家總結(jié)介紹了關(guān)于SQL中一些小巧但常用的關(guān)鍵字,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-03-03
  • sql注入之新手入門示例詳解

    sql注入之新手入門示例詳解

    這篇文章僅僅是對SQL注入進(jìn)行了一個簡單的入門知識的講解,是sql注入的基礎(chǔ)篇,有個好的開頭能夠幫助大家對SQL注入有一個具體清晰的了解和認(rèn)識。下面來一起看看吧,有需要的可以參考借鑒。
    2016-09-09
  • 使用SQL Mail收發(fā)和自動處理郵件中的擴(kuò)展存儲過程簡介

    使用SQL Mail收發(fā)和自動處理郵件中的擴(kuò)展存儲過程簡介

    使用SQL Mail收發(fā)和自動處理郵件中的擴(kuò)展存儲過程簡介...
    2006-12-12
  • Navicat圖形化界面之Navicat?Premium?12?安裝與使用教程

    Navicat圖形化界面之Navicat?Premium?12?安裝與使用教程

    Navicat?premium?是一款數(shù)據(jù)庫管理工具,它可以讓你以單一程式同時連線到?MySQL、SQLite、Oracle?及?PostgreSQL?資料庫,讓管理不同類型的資料庫更加的方便,下面通過本文給大家介紹Navicat?Premium?12?安裝使用教程,需要的朋友參考下吧
    2021-12-12
  • [轉(zhuǎn)載]讓SQL運(yùn)行得更快

    [轉(zhuǎn)載]讓SQL運(yùn)行得更快

    筆者在工作實踐中發(fā)現(xiàn),不良的SQL往往來自于不恰當(dāng)?shù)乃饕O(shè)計、不充份的連接條件和不可優(yōu)化的where子句。在對它們進(jìn)行適當(dāng)?shù)膬?yōu)化后,其運(yùn)行速度有了明顯地提高!下面我將從這三個方面分別進(jìn)行總結(jié)
    2007-02-02
  • 使用DataGrip連接Hive的詳細(xì)步驟

    使用DataGrip連接Hive的詳細(xì)步驟

    這篇文章主要介紹了DataGrip連接Hive的詳細(xì)圖文教程,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-11-11
  • 聚合函數(shù)和group by的關(guān)系詳解

    聚合函數(shù)和group by的關(guān)系詳解

    大家好,本篇文章主要講的是聚合函數(shù)和group by的關(guān)系詳解,感興趣的同學(xué)趕快來看一看吧,對你有幫助的話記得收藏一下
    2022-01-01
  • 關(guān)于SQL注入中文件讀寫的方法總結(jié)

    關(guān)于SQL注入中文件讀寫的方法總結(jié)

    這篇文章主要給大家介紹了關(guān)于SQL注入中文件的讀寫方法,文中通過示例代碼介紹的非常詳細(xì),相信對大家具有一定的參考價值,需要的朋友們下面來一起看看吧。
    2017-03-03
  • 讓你的insert操作速度增加1000倍的方法

    讓你的insert操作速度增加1000倍的方法

    大家平時都會使用insert語句,特別是有時候需要一個大批量的數(shù)據(jù)來做測試,一條一條insert將會是非常慢的,那么我們?nèi)绾巫屛覀兊膇nser更快呢。
    2009-08-08
  • 經(jīng)常使用的JDBC連接數(shù)據(jù)庫方式

    經(jīng)常使用的JDBC連接數(shù)據(jù)庫方式

    在我們開發(fā)中,幾乎脫離不了連接數(shù)據(jù)庫。并且無論是使用框架還是硬編碼連接數(shù)據(jù)庫,都避免不了寫驅(qū)動類以及連接url。為了方便我們的開發(fā),我們收藏常用的jdbc連接數(shù)據(jù)庫方式。
    2013-04-04

最新評論