MySQL常見問題概覽

來源:互聯網
上載者:User

標籤:form   row   from   組織   操作   number   資料庫   其他   查詢   

最近看了江承堯老師的《MySQL技術內幕:sql編程》,同時結合自己工作中遇到的一些問題,從工程效能以及MySQL本身實際應用出發,總結了一些通過子查詢解決的常見問題

1  行號

  MySQL資料庫在行號方面的支援並不是十分友好,沒有像其他資料庫一樣提供類似row_number解決方案

  demo1:select  empid ,(select count(1) from sales AS t2 where  t2.empid<=t1.empid) as rownum from salas as t2

  通過子查詢解決直觀易懂,但是效能很差,每條記錄都需要在相互關聯的子查詢上進行一次尋找,產生笛卡爾積。掃描成本0(N^2)

  select emp_no,dept_no,@a:[email protected]+1 as row_num form dept_emp,(select @a:=0) t 。掃描成本0(N),所以使用交叉串連(cross join)產生行號效率更高

2  分區

  分區和分表相似,都是按照規則分解表。不同在於分表將大表分解為若干個獨立的實體表,而分區是將資料分段劃分在多個位置存放,可以是同一塊磁碟也可以在不同的機器。分區後,表面上還是一張表,但資料散列到多個位置了。app讀寫的時候操作的還是大表名字,db自動去組織分區的資料。相對於分表,不需要建立子表和配置表之間的union關係。分區主要是通過在集合中進行分組操作,再對集合添加分區列來實現的,在子查詢的解決方案中,通過在子查詢內部添加相關性,並匹配內部表和外部表格的分區列來實現分區。

  這裡介紹一種基於暫存資料表的分區解決方案:可以在暫存資料表中建立一個自增長的序列,按照分區的要求將資料插入暫存資料表,需要藉助巢狀查詢解決問題。

MySQL常見問題概覽

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.