1 | <?php |
||
4 | class QueryEngine |
||
5 | { |
||
6 | |||
7 | private $db; |
||
8 | |||
9 | 26 | public function setDriver($driver) |
|
13 | |||
14 | 26 | private function filter($query) |
|
18 | |||
19 | public function getInsertQuery($model) |
||
20 | { |
||
21 | $data = $model->getData(); |
||
22 | $fields = array_keys($data[0]); |
||
23 | $quotedFields = []; |
||
24 | $valueFields = []; |
||
25 | |||
26 | foreach ($fields as $field) { |
||
27 | $quotedFields[] = $this->db->quoteIdentifier($field); |
||
28 | $valueFields[] = ":{$field}"; |
||
29 | } |
||
30 | |||
31 | return $this->filter( |
||
32 | "INSERT INTO " . $this->db->quoteIdentifier($model->getTable()) . |
||
33 | " (" . implode(", ", $quotedFields) . ") VALUES (" . implode(', ', $valueFields) . ")" |
||
34 | ); |
||
35 | } |
||
36 | |||
37 | 6 | public function getBulkUpdateQuery($data, $parameters) |
|
51 | |||
52 | public function getUpdateQuery($model) |
||
53 | { |
||
54 | $data = $model->getData(); |
||
55 | $fields = array_keys($data[0]); |
||
56 | $valueFields = []; |
||
57 | $conditions = []; |
||
58 | $primaryKey = $model->getDescription()->getPrimaryKey(); |
||
59 | |||
60 | foreach ($fields as $field) { |
||
61 | $quotedField = $this->db->quoteIdentifier($field); |
||
62 | |||
63 | if(array_search($field, $primaryKey) !== false) { |
||
64 | $conditions[] = "{$quotedField} = :{$field}"; |
||
65 | } else { |
||
66 | $valueFields[] = "{$quotedField} = :{$field}"; |
||
67 | } |
||
68 | } |
||
69 | |||
70 | return $this->filter("UPDATE " . |
||
71 | $this->db->quoteIdentifier($model->getTable()) . |
||
72 | " SET " . implode(', ', $valueFields) . |
||
73 | " WHERE " . implode(' AND ', $conditions) |
||
74 | ); |
||
75 | } |
||
76 | |||
77 | 18 | public function getSelectQuery($parameters) |
|
90 | |||
91 | public function getCountQuery($parameters) |
||
100 | |||
101 | 2 | public function getDeleteQuery($parameters) |
|
110 | } |
||
111 |
Our type inference engine in quite powerful, but sometimes the code does not provide enough clues to go by. In these cases we request you to add a
@return
annotation as described here.