自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

高效MySQL數(shù)據(jù)庫的正確編寫

數(shù)據(jù)庫 MySQL
我們今天主要向大家描述的是高效的MySQL數(shù)據(jù)庫的正確編寫方案,以下就是對(duì)編寫高效的MySQL數(shù)據(jù)庫的實(shí)際操作方案的具體描述。

以下的文章主要介紹的是編寫高效的MySQL數(shù)據(jù)庫的正確方案,我們首先是借助Apach、Perl與PHP以及Python等實(shí)際應(yīng)用工具,來構(gòu)建一個(gè)關(guān)于MySQL(和PHP搭配之最佳組合),其應(yīng)用時(shí)很容易的。

然而確保它們運(yùn)行快速,則需要一點(diǎn)洞察力。本文就是你需要知道的東西。

MySQL(和PHP搭配之最佳組合)對(duì)于成為一個(gè)非??焖俚腗ySQL數(shù)據(jù)庫服務(wù)器有著當(dāng)之無愧的名聲,它也非常容易設(shè)置和使用。隨著它作為網(wǎng)站后端數(shù)據(jù)庫得聲望日增,其效果在去年開始有明顯提高。但是很多MySQL(和PHP搭配之最佳組合)用戶更多地知道如何創(chuàng)建一個(gè)數(shù)據(jù)庫并編寫對(duì)它的查詢。就像成千上萬的人通過載閑暇時(shí)用Linux做實(shí)驗(yàn)來學(xué)習(xí)Unix那樣,很多人通過玩MySQL(和PHP搭配之最佳組合)學(xué)習(xí)關(guān)系數(shù)據(jù)庫。這些MySQL(和PHP搭配之最佳組合)新手的大多數(shù)既沒有關(guān)系MySQL數(shù)據(jù)庫理論的背景,又沒有時(shí)間閱讀MySQL(和PHP搭配之最佳組合)手冊(cè)全文。

因此,我們決定研究某些方法,你可以用針對(duì)優(yōu)化性能來調(diào)節(jié)MySQL(和PHP搭配之最佳組合)。在讀完本文后,你將理解一些幫助你設(shè)計(jì)你的MySQL(和PHP搭配之最佳組合)數(shù)據(jù)庫和查詢的技術(shù),值得你的應(yīng)用很有效率。我們將假定你熟悉MySQL(和PHP搭配之最佳組合)和SQL基礎(chǔ),但不假定你有這兩方面的廣博知識(shí)。

只存儲(chǔ)你需要的信息

這聽上去是常識(shí),但人們常常采取“廚房下水道”的方式進(jìn)行數(shù)據(jù)庫設(shè)計(jì)。他們認(rèn)為可能項(xiàng)要得每樣?xùn)|西都要存儲(chǔ)并設(shè)計(jì)數(shù)據(jù)庫保存所有者這些數(shù)據(jù)。你需要對(duì)你的需求現(xiàn)實(shí)些,并確定取確實(shí)需要什么信息。你常常能隨意產(chǎn)生一些數(shù)據(jù)而不把它存在MySQL數(shù)據(jù)庫表中。在這種情況下,從一個(gè)應(yīng)用開發(fā)者的角度看也有道理這樣做。

例如,在線目錄的產(chǎn)品表可能包含各種產(chǎn)品的名稱、介紹、尺寸、重量和價(jià)格。除了價(jià)格,你可能想存儲(chǔ)每個(gè)項(xiàng)目相關(guān)的稅和運(yùn)輸成本。但實(shí)際上不必這樣做。首先稅和運(yùn)輸成本可以方便地(由你的應(yīng)用或MySQL(和PHP搭配之最佳組合))計(jì)算出來。其次,如果稅和運(yùn)輸成本改變了,你可能必須編寫必要的查詢更新每個(gè)產(chǎn)品記錄中的稅和運(yùn)輸?shù)馁M(fèi)率。

有時(shí)人們認(rèn)為這太難不能在以后往MySQL數(shù)據(jù)庫表中加入字段,所以他們感覺不得不定義盡可能多的列。這是明顯的概念錯(cuò)誤。在MySQL(和PHP搭配之最佳組合)中,你可以用ALTER TABLE命令方便地修改表定義以適應(yīng)你改變的需求。

例如,如果你突然認(rèn)識(shí)到你需要給你的產(chǎn)品表增加一個(gè)級(jí)別列(可能你想允許用戶在你的目錄中給產(chǎn)品評(píng)級(jí)),你可以這樣做:

 

  1. ALTER TABLE products ADD rank INTEGER 

這給你的產(chǎn)品表增加了一個(gè)整數(shù)類型的級(jí)別列,你能用ALTER TABLE做什么的完整介紹參見MySQL(和PHP搭配之最佳組合)手冊(cè)。

只要求你需要的東西--要清晰

就像說“只存儲(chǔ)你需要的東西”那樣,這可能看來是常識(shí),但這一點(diǎn)常常被忽視,為什么呢?因?yàn)樵谝粋€(gè)應(yīng)用開發(fā)時(shí),需求經(jīng)常改變,所以很多查詢最終看來是這樣:

  1. SELECT * FROM sometable 

當(dāng)你不能肯定你將需要哪一列時(shí),要求所有列明顯是最省力的事情,然而隨著你的表不斷增大和修改,這可能變成一個(gè)性能問題。最好是在你的最初開發(fā)完成后再花些時(shí)間并確定你真正從你的查詢中需要什么:

  1. SELECT name, rank, description FROM products 

這帶來了一個(gè)相關(guān)的觀點(diǎn),即代碼維護(hù)比性能更重要。大多數(shù)變成語言(Perl、Python、PHP、Java等)允許通過字段名和數(shù)字編號(hào)訪問一條查詢的結(jié)果,這意味著你可以訪問命名字段或字段0都可以得到相同的數(shù)據(jù)。

長(zhǎng)期看,最好使用列名而不是其編號(hào)位置,為什么?因?yàn)橐粋€(gè)表中或一條查詢中地列的相對(duì)位置可以改變。它們?cè)诒碇锌赡芤驗(yàn)橹貜?fù)使用ALTER TABLE而改變,它們?cè)诓樵冎袑⒁蛑貙懥瞬樵兌浉聭?yīng)用邏輯來匹配而改變。

當(dāng)然,你仍然需要小心改變列名!但如果你使用列名而非標(biāo)號(hào)位置,如列名改變,你可以用grep搜索源代碼或使用編輯器的搜索能力查找你需要修改的代碼。

以上的相關(guān)內(nèi)容就是對(duì)教你如何編寫高效的MySQL數(shù)據(jù)庫應(yīng)用的介紹,望你能有所收獲。

【編輯推薦】

  1. 對(duì)開源MySQL數(shù)據(jù)庫的介紹
  2. 對(duì)MySQL鏡像數(shù)據(jù)庫進(jìn)行建立在linux下
  3. MySQL索引被破壞所產(chǎn)生的問題解決
  4. MySQL5字符集問題的解決方案
  5. MySQL啟動(dòng)方法與實(shí)際操作步驟
責(zé)任編輯:佚名 來源: 博客園
相關(guān)推薦

2010-06-12 12:45:14

高效MySQL數(shù)據(jù)庫

2011-03-24 13:09:11

數(shù)據(jù)庫代碼

2010-06-01 12:51:23

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

2010-05-11 10:12:50

mysql數(shù)據(jù)庫sql

2010-05-26 11:21:00

MySQL數(shù)據(jù)庫操作

2010-05-25 09:47:05

2010-06-10 17:19:05

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

2010-06-09 10:47:36

MySQL數(shù)據(jù)庫集群

2010-06-07 17:38:41

安裝MySQL 數(shù)據(jù)庫

2010-06-10 17:05:28

2010-06-04 11:21:41

連接MySQL數(shù)據(jù)庫

2010-04-21 09:01:48

MySQL

2023-10-09 18:13:14

MySQL數(shù)據(jù)庫查詢

2010-06-10 10:57:57

2010-06-11 13:22:32

2010-05-14 15:43:32

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

2010-06-11 17:24:47

MySQL鏡像數(shù)據(jù)庫

2010-05-05 10:19:19

Oracle數(shù)據(jù)導(dǎo)

2024-04-16 09:29:53

2024-03-28 09:00:00

NoSQL數(shù)據(jù)庫
點(diǎn)贊
收藏

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