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 進行自動型別轉換,因為轉換過程也會使索引變得不起作用。
資料庫mysql軟體安裝 資料庫軟體mysql安裝
2.解壓至欲安裝的目錄下 3.開啟cmd,進入軟體目錄下d qmdownload mysql 5.7.24 winx64 bin,執行mysqld 4.初始化使用者 cmd d qmdownload mysql 5.7.24 winx64 bin,執行mysqld initialize insecu...
mysql資料庫de mysql資料庫效能篇
慢查詢 超過設定時間的sql語句會被記錄到指定檔案內 1 觀察mysql慢查詢預設的時間 預設10秒 show variables like long 2 修改慢查詢設定時間 set long query time 1 3 檢查mysql是否開啟自動記錄功能 預設關閉 show variables ...
mysql資料庫之python鏈結mysql
使用之前請在命令列pip install pymysql import pymysql 1.建立鏈結 conn pymysql.connect host 127.0.0.1 ip位址 port 3306,埠號 database database name 資料庫名稱 user mysql usern...