colly_wyx
2018-06-14 bef2c06923d3ba6727654f734bb93d5a09855dc5
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
<?php
/**
 * 数据库MQ
 * 
 * - 队列存放于数据库表中,并支持分表
 * 
 * @author dogstar <chanzonghuang@gmail.com> 20150516
 */
 
class Model_Task_TaskMq extends PhalApi_Model_NotORM {
 
    protected function getTableName($id = NULL) {
        $prefix = hexdec(substr(sha1($id), -1)) % 10;
        return 'task_mq_' . $prefix;
    }
 
    public function add($service, $params = array()) {
        $data = array(
            'service' => $service,
            'params' => json_encode($params),
            'create_time' => time(),
        );
 
        $id = $this->insert($data, $service);
 
        return $id > 0 ? TRUE : FALSE;
    }
 
    public function pop($service, $num = 1) {
        $rows = $this->getORM($service)
            ->select('id, params')
            ->where('service', $service)
            ->order('id ASC')
            ->limit(0, $num)
            ->fetchAll();
 
        if (empty($rows)) {
            return array();
        }
 
        $ids = array();
        foreach ($rows as $row) {
            $ids[] = $row['id'];
        }
 
        $this->getORM($service)->where('id', $ids)->delete();
 
        $rs = array();
        foreach ($rows as $row) {
            $params = json_decode($row['params'], TRUE);
            if (!is_array($params)) {
                $params = array();
            }
 
            $rs[] = $params;
        }
 
        return $rs;
    }
}