count (*) 和 count (1) 和 count (列名) 區別

CrazyZard發表於2019-10-15

執行效果:

  • count()包括了所有的列,相當於行數,在統計結果的時候, 不會忽略列值為NULL
  • count(1)包括了忽略所有列,用1代表程式碼行,在統計結果的時候,不會忽略列值為NULL  
  • count(列名)只包括列名那一列,在統計結果的時候,會忽略列值為空(這裡的空不是隻空字串或者0,而是表示null)的計數,即某個欄位值為NULL時,不統計

執行效率: 

  • 列名為主鍵,count ( 列名 )會比 count (1) 快  
  • 列名不為主鍵,count (1) 會比 count (列名) 快  
  • 如果表多個列並且沒有主鍵,則 count (1) 的執行效率優於 count (*)
  • 如果有主鍵,則 select count(主鍵)的執行效率是最優的  
  • 如果表只有一個欄位,則 select count (*) 最優。

相關文章