mysql - 把一個表中的數(shù)據(jù)count更新到另一個表里?
問題描述
UPDATE sites left join comments on comments.siteurl=sites.siteurl SET commentcount = count(comments.siteurl)
報錯:#1111 - Invalid use of group function
sites是網(wǎng)站表comments表是評論一個網(wǎng)站對應(yīng)多個評論現(xiàn)在想把評論的數(shù)量統(tǒng)計出來直接更新到sites
找到個方法了:
UPDATE sites A INNER JOIN (SELECT *, COUNT(*) idcount FROM comments GROUP BY siteurl) as B ON B.siteurl = A.siteurlSET A.commentcount = B.idcount
問題解答
回答1:為何要將count寫入site表 那豈不是每次comment表數(shù)據(jù)更新了你都要那count重新寫入site?這樣不麻煩嗎?如果你只是想統(tǒng)計每個site的評論數(shù)。每次查詢的時候像你之前那樣鏈表就行了
回答2:count是聚合函數(shù),直接這樣寫是不行的。你可以先把所有的數(shù)量查出來,然后直接在update的時候set commentcount=總數(shù)
相關(guān)文章:
1. mac連接阿里云docker集群,已經(jīng)卡了2天了,求問?2. css - jq有無現(xiàn)成函數(shù)改變rotateX/Y的deg3. PHP類封裝的插入數(shù)據(jù),總是插入不成功,返回false;4. javascript - 關(guān)于ios微信端瀏覽器網(wǎng)頁的一些問題5. python - JWT, django如何定制關(guān)于用戶的Permission?6. objective-c - 微信支付的問題7. nginx - 微信JSSDK,config執(zhí)行的時候報錯:invalid signature8. javascript - web移動端 ? 版權(quán)這個字在安卓上默認藍色顏色 怎么解決?9. javascript - 怎么實現(xiàn)移動端頁面滑動切換,從1可以滑到2 但是不能從2滑回1 這樣的效果呢?10. 自己安裝了apache2.2,但是重啟apache后出錯了,求解!謝謝!
