26楼代码再贴下:
lib/elementupdate.class.php
- function hotfavorUpdate($tid, $fid) {
- if (!($this->ifcache & 1024) || !$tid || !$fid) {
- return false;
- }
- $eid = $this->db->get_value("SELECT eid FROM pw_elements WHERE type='hotfavor' AND mark=" . S::sqlEscape($fid) . " AND id=" . S::sqlEscape($tid));
- if ($eid) {
- $this->db->update("UPDATE pw_elements SET value=value+1 WHERE eid=" . S::sqlEscape($eid));
- } else {
- $rt = $this->db->get_one("SELECT favors FROM pw_threads WHERE tid=" . S::sqlEscape($tid));
- $rs = $this->db->get_one("SELECT value,eid FROM pw_elements WHERE type='hotfavor' ORDER BY value ASC");
- if ($rt['favors'] > $rs['value']) {
- $this->db->update("DELETE FROM pw_elements WHERE eid=" . S::sqlEscape($rs['eid']));
- $favors = array(
- 'id' => $tid,
- 'mark' => $fid,
- 'value' => $rt['favors'],
- 'type' => 'hotfavor'
- );
- $this->db->update("REPLACE INTO pw_elements SET" . S::sqlSingle($favors, false));
- }
- }
- return true;
- }
简单说下我的理解:
第5行,从FROM pw_elements里查询eid(就是一个序号,类型为自增),查询条件为type字段为收藏排行(hotfavor),mark字段为当前版块fid,id字段为当前主题的tid。
说白了,就是查询当前主题是不是在收藏排行里;第6行,如果为真,也就是当前主题已经在收藏排行里;
第7行,更新对应eid行的收藏数为原收藏数+1,也就是对于已经是收藏排行的主题,每当被收藏一次,在这个表里收藏数就会增加1;
第8行,否则,也就是当前主题不在收藏排行top50里。这种情况下的代码,从第9行开始一直到22行。