校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > 深入淺出的學習Mysql

深入淺出的學習Mysql

熱門標簽:dq8 全地圖標注 電銷機器人市場價 邯鄲400電話注冊辦理 遂寧400電話申請 南寧智能電銷機器人價格 哈爾濱云外呼系統運營商 趙縣地圖標注 永州智能外呼系統 地圖標注直通車

前言

數據庫一直是筆者比較薄弱的地方,結合自己的使用經驗(python+sqlalchemy)等做個記錄,筆者比較喜歡使用ORM,一直感覺拼sql是一件比較痛苦的事情(主要是不擅長sql),以前維護項的目中也遇到過一些數據庫的坑,比如編碼問題,浮點數精度損失等,防止以后重復踩坑。

1章:使用幫助

使用mysql內置的幫助命令

  1. msyql> ? data types : 查看數據類型
  2. mysql> ? int
  3. mysql> ? create table

2章:表類型(存儲引擎)的選擇

最常用的兩種引擎:

1、Myisam是Mysql的默認存儲引擎,當create創建新表時,未指定新表的存儲引擎時,默認使用Myisam。 每個MyISAM 在磁盤上存儲成三個文件。文件名都和表名相同,擴展名分別是 .frm (存儲表定義) 、.MYD (MYData,存儲數據)、.MYI (MYIndex,存儲索引)。數據文件和 索引文件可以放置在不同的目錄,平均分布io,獲得更快的速度。

2、InnoDB 存儲引擎提供了具有提交、回滾和崩潰恢復能力的事務安全。但是對比 Myisam 的存儲引擎,InnoDB 寫的處理效率差一些并且會占用更多的磁盤空間以保留數據和索引。

常用環境:

1、MyISAM: 默認的 MySQL 插件式存儲引擎, 它是在 Web、 數據倉儲和其他應用環境下最常
使用的存儲引擎之一

2、InnoDB:用于事務處理應用程序,具有眾多特性,包括 ACID 事務支持。

3章:選擇合適的數據類型

首先選擇合適的存儲引擎,根據指定的存儲引擎確定合適的數據類型。

  • MyISAM: 最好使用固定長度的數據列代替可變長度的數據列。
  • InnoDB: 建議使用varchar

需要注意的一些數據類型:

1、char與varchar: 保存和檢索方式不同,最大長度和是否尾部空格被保留也不同。char固定長度,長度不夠用空格填充,獲取時如果沒有設置 PAD_CHAR_TO_FULL_LENGTH默認去除尾部空格。
varchar變長字符串,檢索時尾部空格會被保留。注意查詢時候不區分大小寫,如果用sqlalchemy區分大小寫不要用func.binary函數。

2、text和blob: text和blob執行大量的更新或者刪除的時候會留下很大『空洞』,建議定期用OPTIMIZE TABLE功能對這類表碎片整理。避免檢索大型的blob或text值 。把text和blob列分離到單獨的表中。

3、浮點數float與定點數decimal:

注意幾個點:

      1.浮點數雖然能表示更大的數據范圍,但是有誤差問題。

      2.對貨幣等精度敏感的問題,應使用定點數存儲。之前項目踩過坑,結果不得不用放大和縮小倍數的方法解決,比較ugly。

      3.編程如果遇到浮點數,注意誤差問題,盡量避免浮點數比較(比較浮點數需要作差小于一個特定精度),python3.5中可以這么比較:float_eq = partial(math.isclose, rel_tol=1e-09, abs_tol=0.0)

      4.注意浮點數中一些特殊值的處理。

4章:字符集

一開始要選擇合適的字符集,否則后期更換代價很高。python2中字符集就是個老大難問題,困然很多新手。之前維護過的項目使用了msyql默認的latin1字符集,導致每次寫入的時候都要對字符串手動encode成utf8。最近用python3.5+flask做項目直接使用utf8,再也沒碰到過編碼問題:

  • 創建數據庫使用utf8,CREATE DATABASE IF NOT EXISTS my_db default charset utf8 COLLATE utf8_general_ci;
  • sqlalchemy連接url使用mysql://root:root@127.0.0.1:3306/my_db?charset=utf8。不用擔心亂碼問題了

5章:索引的設計和使用

所有mysql列類型都可以被索引,對相關列使用索引是提高select操作性能的最佳途徑。索引設計的原則:

      1.搜索的索引列,不一定是所要選擇的列。最適合的索引的列是出現在where子句中的列,或連接子句中指定的列,而不是出現在select關鍵字之后的選擇列表中的列。

      2.使用唯一索引。對于唯一值的列,索引效果較好,而有多個重復值的列,索引效果差。

      3.使用短索引。如果對字符串列進行索引,應指定一個前綴長度,只要有可能就應該這樣做。

      4.利用最左前綴。在創建一個n列索引時,實際上創建了mysql可利用的n個索引。多列索引可以起到幾個索引的作用,因為可利用索引中的最左邊的列集來匹配行,這樣的列集成為最左前綴。

      5.不要過度索引。索引會浪費磁盤空間,降低寫入性能。

      6.考慮在列上進行的比較類型。

6章:鎖機制和事務控制

InnoDB引擎提提供行級鎖,支持共享鎖和排他鎖兩種鎖定模式,以及四種不同的隔離級別。mysql通過AUTOCOMIT, START TRANSACTIONS, COMMIT和ROLLBACK等語句支持本地事務。

7章:SQL中的安全問題

SQL注入:利用某些數據庫的外部接口把用戶數據插入到實際的數據庫操作語音(sql)中,從而達到入侵數據庫甚至操作系統的目的。產生原因主要是因為程序堆用戶輸入的數據沒有進行嚴格的過濾,導致非法數據庫查詢語句的執行,防范措施:

  1. prepareStatement = Bind-variable,不要使用拼接的sql
  2. 使用應用程序提供的轉換函數
  3. 自定義函數校驗(表單校驗等)

8章:SQL Mode及相關問題

更改默認的mysql執行模式,比如嚴格模式下列的插入或者更新不正確時mysql會給出錯誤,并放棄操作。set session sql_mode='STRICT_TRANS_TABLES'。設置sql_mode需要應用人員權衡各種得失,做一個合適的選擇。

9章:常用SQL技巧

  1. 檢索包含最大/最小值的行:MAX([DISTINCE] expr), MIN([DISTINCE] expr)
  2. 巧用rand()/rand(n)提取隨機行
  3. 利用group bywith rollup子句做統計
  4. bit group functions做統計

10章:其他需要注意的問題

數據庫名、表名大小寫問題:不同平臺和系統,是否區分大小寫是不同的。建議就是始終統一使用小寫名。
使用外鍵需要注意的地方:mysql中InnoDB支持對外部關鍵字約束條件的檢查。

11章:SQL優化

優化SQL的一般步驟:

      1.使用show status和應用特點了解各種SQL的執行頻率,了解各種SQL大致的執行比例。比如InnoDB的的參數Innode_rows_read查詢返回的行數,Innodb_rows_inserted執行insert插入的行數,Innodb_rows_updated更新的行數。還有一下幾個參數:Connections試圖連接mysql服務器嗯出書,Uptime服務器的工作時間,Slow_queries慢查詢的次數。

      2.定位執行效率低的SQL語句。兩種方式:一種是通過慢查詢日志定位執行效率低的語句,使用—log-slow-queries[=file_name]選項啟動時,mysqld寫一個包含所有執行時間超過long_query_time秒的SQL語句的日志文件。另一種是show processlist查看當前mysql在進行的線程,包括線程的狀態,所否鎖表等,可以實時查看SQL執行情況,同時對一些鎖表操作進行優化。

      3.通過EXPLAIN分析低效SQL的執行計劃:explain可以知道什么時候必須為表假如索引以得到一個使用索引來尋找記錄的更快的SELECT,以下是EXPLAIN執行后得到的結果說明:

  • select_type: select類型
  • table: 輸出結果集的表
  • type: 表示表的連接類型。當表中僅有一行是type的值為system是最佳的連接類型;當select操作中使用索引進行表連接時type值為ref;當select的表連接沒有使用索引時,經常看到type的值為ALL,表示對該表進行了全表掃描,這時需要考慮通過創建索引提高表連接效率。
  • possible_keys: 表示查詢時,可以使用的索引列。
  • key: 表示使用的索引
  • key_len: 索引長度
  • rows: 掃描范圍
  • Extra: 執行情況的說明和描述

      4.確定問題,并采取相應優化措施。

索引問題

  1. 索引的存儲分類: myisam表的數據文件和索引文件自動分開,innodb的數據和索引放在同一個表空間里面。myisam和innodb的索引存儲類型都是btree
  2. Mysql如何使用索引: 索引用于快速查找某個列中特定值的行。查詢要使用索引最主要的條件是要在查詢條件中使用索引關鍵子,如果是多列索引,那么只有查詢條件中使用了多列關鍵字最左邊的前綴時,才可以使用索引,否則將不能使用索引。
  3. 查看索引的使用情況:Handler_read_key的值代表一個行被索引次數,值低表示索引不被經常使用。Handler_read_rnd_next值高意味著查詢運行低效,應該建立索引補救。show status like 'Handler_read%';

兩個簡單實用的優化方法

  • 定期分析表:ANALYZE TABLE, CHECK TABLE, CHECKSUM TABLE
  • 使用OPTIMIZE table;

從客戶端(代碼端)角度優化

  1. 使用持久的連接數據庫以避免連接開銷。代碼中我們一般使用連接池
  2. 檢查所有的插敘確實使用了必要的索引。
  3. 避免在頻繁更新的表上執行復雜的select查詢,以避免與鎖表有關的由于讀,寫沖突發生的問題。
  4. 充分利用默認值,只有插入值不同于默認值才明確插入值。減少mysql需要做的語法分析從而提高插入速度。
  5. 讀寫分離提高性能
  6. 表字段盡量不用自增長變量,防止高并發情況下該字段自增影響效率,推薦通過應用實現字段的自增。

12章: 優化數據庫對象

優化表的數據類型:PROCEDURE ANALYZE()對當前表類型的判斷提出優化建議。實際可以通過統計信息結合應用實際優化。

通過拆分,提高表的訪問效率:這里拆分主要是針對Myisam類型的表。

  • 縱向拆分:按照應用訪問的頻度,將表中經常訪問的字段和不經常訪問的字段拆分成兩個表,經常訪問的字段盡量是定長的。
  • 橫向拆分:按照應用情況,有目的地將數據橫向拆分成幾個表或者通過分區分到多個分區中,這樣可以有效避免Myisam表的讀取和更新導致的鎖問題。

逆規范化:規范化設計強調獨立性,數據盡可能少冗余,更多冗余意味著占用更多物理空間,同事也對數據維護和一致性檢查帶來問題。適當冗余可以減少多表訪問,查詢效率明顯提高,這種情況可以考慮適當通過冗余提高效率。

使用冗余統計表:使用create temporary table做統計分析

選擇更合適的表類型:1.如果應用出現比較嚴重的鎖沖突,請考慮是否刻意更改存儲引擎到InnoDB,行鎖機制可以有效減少鎖沖突出現。2.如果應用查詢操作很多,且對事務完整性要求不嚴格,可以考慮使用Myisam。

13章:鎖問題

獲取鎖的等待情況:table_locks_waited和table_locks_immediate狀態變量來分析系統上的表鎖定爭奪。檢查Innode_row_lock分析行鎖的爭奪情況。

14章:優化Mysql Server

查看Mysql Server當前參數

  1. 查看服務器參數默認值:mysqld --verbose --help
  2. 查看服務器參數實際值:shell> mysqladmin variables or mysql> SHOW VARIABLES
  3. 查看服務器運行狀態值:mysqladmin extended-status or mysql>SHOW STATUS

影響Mysql性能的重要參數

  1. key_buffer_size: 鍵緩存
  2. table_cache: 數據庫中打開的緩存數量
  3. innode_buffer_pool_size: 緩存InnoDB數據和索引的內存緩沖區的大小
  4. innodb_flush_log_at_trx_commit: 推薦設成1,在每個事務提交時,日志緩沖被寫到日志文件,對日志文件做到磁盤操作的刷新。

15章:I/O問題

磁盤搜索是巨大的性能瓶頸。

  1. 使用磁盤陣列或虛擬文件卷分布I/O
  2. 使用Symbolic Links分布I/O

16章:應用優化

  1. 使用連接池:建立連接代價比較高,通過建立連接池提高訪問性能。
  2. 減少對Mysql的訪問:1.避免對同意數據重復檢索。2使用mysql query cache
  3. 增加cache層
  4. 負載均衡:1.利用mysql復制分流查詢操作。2分布式數據庫架構

總結

以上就是關于mysql的相關內容,希望本文的內容對大家學習或者使用mysql能帶來一定的幫助,如果有疑問大家可以留言交流。

您可能感興趣的文章:
  • mysql安裝圖解 mysql圖文安裝教程(詳細說明)
  • MySQL日期數據類型、時間類型使用總結
  • MySQL創建用戶與授權方法
  • mySQL中replace的用法
  • mysql存儲過程詳解
  • MYSQL導入導出命令詳解
  • 完全卸載mysql(停止服務、卸載相關程序、刪除注冊表
  • MySQL觸發器使用詳解
  • MySQL錯誤代碼大全
  • MySql查詢時間段的方法

標簽:張家界 上海 阿里 定西 南寧 中衛 鄂州 浙江

巨人網絡通訊聲明:本文標題《深入淺出的學習Mysql》,本文關鍵詞  深入淺出,的,學習,Mysql,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《深入淺出的學習Mysql》相關的同類信息!
  • 本頁收集關于深入淺出的學習Mysql的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    亚洲人妖av一区二区| 免费看日韩精品| 成人激情免费电影网址| 国产婷婷一区二区| 久久er99精品| 欧美日本视频在线| 日韩国产精品大片| 日韩写真欧美这视频| 久久99精品久久久久久国产越南| www国产成人| eeuss鲁片一区二区三区在线看| 中文字幕一区二区5566日韩| 色94色欧美sute亚洲13| 三级在线观看一区二区| 久久亚洲春色中文字幕久久久| 国产很黄免费观看久久| 最新日韩av在线| 欧美日韩一二三区| 国内精品视频666| 成人欧美一区二区三区小说| 欧美日韩极品在线观看一区| 精品一区二区成人精品| 亚洲欧洲av另类| 欧美高清视频在线高清观看mv色露露十八| 日本中文字幕一区二区有限公司| 久久久久久久久久久电影| 成人高清在线视频| 国产在线播放一区二区三区| 91麻豆精品国产91久久久久 | 成人av网站免费观看| 亚洲男人天堂一区| 欧美一区二区日韩| 成人蜜臀av电影| 无码av中文一区二区三区桃花岛| 欧美精品一区二区三区在线 | 欧美日韩在线综合| 精品一区在线看| 亚洲摸摸操操av| 精品国产电影一区二区| 欧美亚洲一区二区在线观看| 久久精品亚洲精品国产欧美| 久久精品夜色噜噜亚洲a∨| 成人自拍视频在线| 五月婷婷色综合| 国产精品久久夜| 欧美电视剧在线看免费| 在线观看免费视频综合| 国产精品一级片| 日本欧美在线观看| 亚洲精品v日韩精品| 国产女人18毛片水真多成人如厕 | 91视视频在线观看入口直接观看www| 五月天亚洲婷婷| 亚洲精品视频在线看| 中文字幕乱码久久午夜不卡| 91精品国产手机| 91国偷自产一区二区三区成为亚洲经典| 国产综合色产在线精品| 五月激情六月综合| 亚洲一区二区三区中文字幕在线| 精品国产乱码久久久久久浪潮 | ...xxx性欧美| 欧美一级理论性理论a| 91农村精品一区二区在线| 国产一区在线观看视频| 日韩av成人高清| 丝袜国产日韩另类美女| 亚洲另类春色校园小说| 中文字幕在线视频一区| 中文一区二区在线观看| 久久精品亚洲精品国产欧美| 久久这里都是精品| 精品久久一二三区| 日韩欧美一级片| 日韩一区二区麻豆国产| 欧美肥妇bbw| 4438亚洲最大| 337p亚洲精品色噜噜噜| 7777精品伊人久久久大香线蕉 | 国产一区二区h| 亚洲成a人片在线观看中文| 亚洲卡通动漫在线| 最新欧美精品一区二区三区| 国产精品国产馆在线真实露脸| 国产视频一区不卡| 国产亚洲欧美色| 国产日产欧产精品推荐色| 欧美精品一区二区三区在线播放| 日韩一级黄色大片| 日韩久久免费av| 精品久久久久香蕉网| 精品免费99久久| 337p日本欧洲亚洲大胆精品| 久久久国产精品不卡| 久久久久亚洲蜜桃| 国产欧美日韩在线| 国产精品三级在线观看| 中文字幕在线不卡一区二区三区| 国产精品网站一区| 亚洲人成在线播放网站岛国| 一区二区三区中文字幕电影| 一区二区三区在线影院| 性久久久久久久久久久久| 免费看黄色91| 国产高清亚洲一区| 91蝌蚪porny九色| 欧美精品色一区二区三区| 欧美大胆人体bbbb| 中文一区一区三区高中清不卡| 亚洲精品免费一二三区| 首页综合国产亚洲丝袜| 92国产精品观看| 欧美婷婷六月丁香综合色| 91麻豆精品国产91久久久| 国产亚洲一区二区三区| 亚洲精品免费在线| 美国十次综合导航| 99久久精品国产导航| 欧美一区二区三区免费在线看| 国产午夜亚洲精品理论片色戒 | www精品美女久久久tv| 1区2区3区国产精品| 亚洲一区在线播放| 国产一区二区三区不卡在线观看 | 91蜜桃网址入口| 欧美一区二区视频观看视频| 国产日韩欧美一区二区三区乱码 | 日韩av中文在线观看| 日韩中文字幕av电影| 91高清在线观看| 色狠狠综合天天综合综合| 欧美人xxxx| 亚洲最新视频在线播放| 韩国在线一区二区| 日韩欧美一区二区久久婷婷| 2欧美一区二区三区在线观看视频| 精品国产一二三| 亚洲乱码国产乱码精品精98午夜| 免费观看在线色综合| 欧美日韩成人在线| 在线亚洲一区二区| 亚洲免费在线视频一区 二区| 伊人婷婷欧美激情| 韩国一区二区三区| 欧美福利一区二区| 午夜伊人狠狠久久| 91网站黄www| 久久婷婷综合激情| 久久精品噜噜噜成人88aⅴ| 国产在线视频一区二区| 不卡的av中国片| 精品视频免费在线| 久久久久久毛片| 免费观看久久久4p| 国产高清无密码一区二区三区| 日韩精品一二区| 一区二区三区免费在线观看| 成人黄色小视频在线观看| 久久婷婷综合激情| 欧洲精品在线观看| 精品国内片67194| 丁香五精品蜜臀久久久久99网站| 一区二区在线观看不卡| 欧美日韩视频专区在线播放| 亚洲欧美激情视频在线观看一区二区三区| 国产精品77777| 久久九九99视频| 国产乱码精品一品二品| 精品区一区二区| 精品午夜久久福利影院| 精品黑人一区二区三区久久| 麻豆成人av在线| 精品国产一区二区三区久久久蜜月 | 亚洲高清在线精品| 一本一道综合狠狠老| 一区二区三区在线播| 日本高清无吗v一区| 一区二区三区欧美| 欧美色图在线观看| 亚洲一区二区三区四区在线免费观看 | 日本不卡在线视频| 欧美肥妇free| 久久国产精品一区二区| 91精品国产综合久久久蜜臀粉嫩| 亚洲一区二区在线播放相泽 | 97精品国产露脸对白| 亚洲天堂中文字幕| 色综合久久九月婷婷色综合| 国产午夜三级一区二区三| 国产成人超碰人人澡人人澡| 国产香蕉久久精品综合网| 波多野结衣91| 亚洲三级小视频| 欧美日韩精品一区二区在线播放| 日韩国产成人精品| 久久毛片高清国产| 97精品电影院| 免费美女久久99| 欧美国产乱子伦 | 亚洲成人免费视频|