mysql 取資料的問題。

來源:互聯網
上載者:User
  1. 我現在有一張表,沒有主鍵,只有一個聯合唯一 (date,user_id,count_name, )
    表格記錄樣本: date:20160808 user_id:556 count_name: a1

  2. date表示日期,user_id 表示使用者的id , count_name 表示某一個統計值。

  3. count_name 可取值 (a1,a2,a3,···,a12,b1,b2,b3,···,b12);

  4. 每天產生的記錄有幾萬條。

  5. 資料庫每次取出記錄上限1萬條。

我現在需要統計12個值。 用mysql語句可以這麼表示:

select count(distinct(`shop_id`)) from count_table where date = '20160808' and count_name in ('a1','b1'); select count(distinct(`shop_id`)) from count_table where date = '20160808' and count_name in ('a2','b2'); ···

這樣取12次資料庫,可以達到結果,但效率不高。

請問有沒有方法可以一次取出想要的資料呢?(這是一個比較老的資料庫,資料量比較大,修改資料庫什麼的做最後的考慮哈!)

嘗試過的方法:

  1. 分頁統計的話,由於表格沒有主鍵,分頁不好處理。

  2. 一次性取出資料在處理,受制於mysql一次只能取出1萬條左右的資料,再多可能就崩潰了。

回複內容:

  1. 我現在有一張表,沒有主鍵,只有一個聯合唯一 (date,user_id,count_name, )
    表格記錄樣本: date:20160808 user_id:556 count_name: a1

  2. date表示日期,user_id 表示使用者的id , count_name 表示某一個統計值。

  3. count_name 可取值 (a1,a2,a3,···,a12,b1,b2,b3,···,b12);

  4. 每天產生的記錄有幾萬條。

  5. 資料庫每次取出記錄上限1萬條。

我現在需要統計12個值。 用mysql語句可以這麼表示:

select count(distinct(`shop_id`)) from count_table where date = '20160808' and count_name in ('a1','b1'); select count(distinct(`shop_id`)) from count_table where date = '20160808' and count_name in ('a2','b2'); ···

這樣取12次資料庫,可以達到結果,但效率不高。

請問有沒有方法可以一次取出想要的資料呢?(這是一個比較老的資料庫,資料量比較大,修改資料庫什麼的做最後的考慮哈!)

嘗試過的方法:

  1. 分頁統計的話,由於表格沒有主鍵,分頁不好處理。

  2. 一次性取出資料在處理,受制於mysql一次只能取出1萬條左右的資料,再多可能就崩潰了。

  • 聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.