1. 選取最適用的字段屬性
表中字段的寬度設得盡可能小:char 的上限為 255 位元組(固定占用空間),varchar 的上限 65535 位元組(實際占用空間),text 的上限為 65535。
盡量把字段設定為 not null,執行查詢的時候,資料庫不用去比較 null 值。
2. 使用連線(join)來代替子查詢 (sub-queries)
連線(join)之所以更有效率一些,是因為 mysql 不需要在記憶體中建立臨時表來完成這個邏輯上的需要兩個步驟的查詢工作(聯合查詢的條件加索引更快)。
3. 使用聯合 (union) 來代替手動建立的臨時表
把需要使用臨時表的兩條或更多的 select 查詢合併的乙個查詢中。
select name, phone from client union select name, birthdate from author union select name, supplier from product;
4. 事務
儘管我們可以使用子查詢(sub-queries)、連線(join)和聯合(union)來建立各種各樣的查詢,但不是所有的資料庫操作都可以只用一條或少數幾條 sql 語句就可以完成的。更多的時候是需要用到一系列的語句來完成某種工作。
作用是:要麼語句塊中每條語句都操作成功,要麼都失敗。換句話說,就是可以保持資料庫中資料的一致性和完整性。事物以 begin 關鍵字開始,commit 關鍵字結束。在這之間的一條 sql 操作失敗,那麼,rollback 命令就可以把資料庫恢復到 begin 開始之前的狀態。
5. 鎖定表
儘管事務是維護資料庫完整性的乙個非常好的方法,但卻因為它的獨占性,有時會影響資料庫的效能,尤其是在很大的應用系統中。由於在事務執行的過程中,資料庫將會被鎖定,因此其它的使用者請求只能暫時等待直到該事務結束。
lock table inventory write
select quantity from inventory
whereitem='book';
update inventory set quantity=11
whereitem='book';
unlock tables
這裡,我們用乙個 select 語句取出初始資料,通過一些計算,用 update 語句將新值更新到表中。包含有 write 關鍵字的 lock table 語句可以保證在 unlock tables 命令被執行之前,不會有其它的訪問來對 inventory 進行插入、更新或者刪除的操作。
6、使用外來鍵
鎖定表的方法可以維護資料的完整性,但是它卻不能保證資料的關聯性。這個時候我們就可以使用外來鍵。例如,外來鍵可以保證每一條銷售記錄都指向某乙個存在的客戶。在這裡,外來鍵可以把 customerinfo 表中的 customerid 對映到 salesinfo 表中 customerid,任何一條沒有合法 customerid 的記錄都不會被更新或插入到 salesinfo 中。create table customerinfo
customerid int not null ,
primary key ( customerid )
) type = innodb;
create table salesinfo
salesid int not null,
customerid int not null,
primary key(customerid, salesid),
foreign key (customerid) references customerinfo
(customerid) on deletecascade
) type = innodb;
注意例子中的引數 「on delete cascade」。該引數保證當 customerinfo 表中的一條客戶記錄被刪除的時候,salesinfo 表中所有與該客戶相關的記錄也會被自動刪除。如果要在 mysql 中使用外來鍵,一定要記住在建立表的時候將表的型別定義為事務安全表 innodb 型別。該型別不是 mysql 表的預設型別。定義的方法是在 create table 語句中加上 type=innodb。
7. 使用索引
查詢語句當中包含有 max (), min () 和 orderby 這些命令的時候,效能提高更為明顯。
索引應建立在那些將用於 join, where 判斷和 order by 排序的字段上。盡量不要對資料庫中某個含有大量重複的值的字段建立索引。對於乙個 enum 型別的字段來說,出現大量重複值是很有可能的情況,例如 customerinfo 中的 「province」.. 字段,在這樣的字段上建立索引將不會有什麼幫助;相反,還有可能降低資料庫的效能。
8. 優化的查詢語句
select from order where year(orderdate)<2001;
select from order where orderdate
select from inventory where amount/7<24;
select from inventory where amount<24*7;
避免在查詢中讓 mysql 進行自動型別轉換,因為轉換過程也會使索引變得不起作用。
PHP MySQL批量插入資料的優化方法
mysql批量插入資料的優化方法,廢話少說直接貼 link mysql connect localhost root or die mysql error mysql select db phone link or die mysql error mysql query set names gbk ...
PHP MySQL分頁的優化
今天在本機布置 的時候,發現後台有乙個功能的分頁特別的慢,要十多秒才能開啟。本身機器也有一點慢,但是才1000多條資料就慢的不得了,以後怎麼辦。分頁的那個sql語句太複雜,有條件,有外鏈結,有排序,非常的慢,上網查了幾種優化方式。最後對 進行了優化,之後2秒就可以開啟了。sql stringx se...
李景山php mysql 配置優化
今天我們不討論其它優化,就就配置上,講講mysql的優化,看看怎麼處理更好。最好是固態硬碟。注意 此處說明的my.cnf可能根據不同的配置位置顯示情況不一樣。檢視當前最大連線數 show variables like max connections 檢視最大響應連線數 show status lik...