| 
									
										
										
										
											2014-06-02 18:58:49 +04:00
										 |  |  | <?php namespace Majestic\Model; | 
					
						
							| 
									
										
										
										
											2011-11-11 18:01:17 +04:00
										 |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * Класс модели данных | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @copyright NetMonsters <team@netmonsters.ru> | 
					
						
							|  |  |  |  * @link http://netmonsters.ru | 
					
						
							|  |  |  |  * @package Majestic | 
					
						
							|  |  |  |  * @subpackage Model | 
					
						
							|  |  |  |  * @since 2011-11-11 | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-10-19 20:15:26 +04:00
										 |  |  | /** | 
					
						
							|  |  |  |  * @property SqlDbDriver $db | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2014-06-02 18:58:49 +04:00
										 |  |  | abstract class SqlModel extends Model | 
					
						
							| 
									
										
										
										
											2011-11-11 18:01:17 +04:00
										 |  |  | { | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param string $ident | 
					
						
							|  |  |  |      * @return string Quoted identifier. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function identify($ident) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return $this->db->quoteIdentifier($ident); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param mixed $value | 
					
						
							|  |  |  |      * @return string Quoted value. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function quote($value) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return $this->db->quote($value); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-03-06 15:26:59 +04:00
										 |  |  |     public function getDb() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return $this->db; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-11 18:01:17 +04:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param int $id | 
					
						
							|  |  |  |      * @return object | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function get($id) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $sql = 'SELECT * FROM :table WHERE :pk=?'; | 
					
						
							|  |  |  |         return $this->fetch($sql, $id); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param array $data | 
					
						
							|  |  |  |      * @param mixed $where | 
					
						
							|  |  |  |      * @return int Number of affected rows | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function update($data, $where) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2013-09-20 22:11:54 +04:00
										 |  |  |         if (is_int($where) || $where === (string)(int)$where) { | 
					
						
							|  |  |  |             $where = $this->identify($this->key) . '=' . (int)$where; | 
					
						
							| 
									
										
										
										
											2011-11-11 18:01:17 +04:00
										 |  |  |         } | 
					
						
							|  |  |  |         return parent::update($data, $where); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param int $id Int id | 
					
						
							|  |  |  |      * @return int Number of affected rows | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function delete($id) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2013-09-20 22:11:54 +04:00
										 |  |  |         $where = $this->identify($this->key) . '=' . (int)$id; | 
					
						
							| 
									
										
										
										
											2011-11-11 18:01:17 +04:00
										 |  |  |         return $this->db->delete($this->table(), $where); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Creates order sql string | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param array $params | 
					
						
							|  |  |  |      * @param array $sortable | 
					
						
							|  |  |  |      * @return string | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     protected function order($params, $sortable = array('id')) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $sql = ''; | 
					
						
							|  |  |  |         if (isset($params['sort'])) { | 
					
						
							| 
									
										
										
										
											2013-09-19 10:05:00 +04:00
										 |  |  |             if (!is_array($params['sort'])) { | 
					
						
							|  |  |  |                 if (isset($params['order'])) { | 
					
						
							|  |  |  |                     $params['order'] = array($params['sort'] => $params['order']); | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 $params['sort'] = array($params['sort']); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             $order_list = array(); | 
					
						
							|  |  |  |             for ($i = 0; $i < count($params['sort']); $i++) { | 
					
						
							|  |  |  |                 $order = (isset($params['order'][$params['sort'][$i]]) && $params['order'][$params['sort'][$i]] == 'desc') ? 'DESC' : 'ASC'; | 
					
						
							|  |  |  |                 if (in_array($params['sort'][$i], $sortable)) { | 
					
						
							| 
									
										
										
										
											2013-09-20 22:11:54 +04:00
										 |  |  |                     $order_list[] = $this->identify($params['sort'][$i]) . ' ' . $order; | 
					
						
							| 
									
										
										
										
											2013-09-19 10:05:00 +04:00
										 |  |  |                 } | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             if ($order_list) { | 
					
						
							|  |  |  |                 $sql = ' ORDER BY ' . implode(',', $order_list); | 
					
						
							| 
									
										
										
										
											2011-11-11 18:01:17 +04:00
										 |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         return $sql; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Searches using like | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param array $params | 
					
						
							|  |  |  |      * @param array $searchable | 
					
						
							|  |  |  |      * @param string $table_prefix | 
					
						
							|  |  |  |      * @return string | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     protected function search($params, $searchable = array('id'), $table_prefix = '') | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $sql = ''; | 
					
						
							|  |  |  |         if (isset($params['q']) && isset($params['qt']) && in_array($params['qt'], $searchable)) { | 
					
						
							|  |  |  |             if ($table_prefix) { | 
					
						
							|  |  |  |                 $sql = $table_prefix . '.'; | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2013-09-20 22:11:54 +04:00
										 |  |  |             $sql .= $this->identify($params['qt']) . ' LIKE ' . $this->quote('%' . $params['q'] . '%'); | 
					
						
							| 
									
										
										
										
											2011-11-11 18:01:17 +04:00
										 |  |  |         } | 
					
						
							|  |  |  |         return $sql; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * This method appends to params table and primary key. | 
					
						
							| 
									
										
										
										
											2012-10-19 20:15:26 +04:00
										 |  |  |      * So they can be accessed through `:table` and `:pk` placeholders. | 
					
						
							| 
									
										
										
										
											2011-11-11 18:01:17 +04:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2012-10-19 20:15:26 +04:00
										 |  |  |      * @param string $sql | 
					
						
							|  |  |  |      * @param array $params | 
					
						
							| 
									
										
										
										
											2011-11-11 18:01:17 +04:00
										 |  |  |      * @return DbStatement | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     protected function query($sql, $params = array()) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if (!is_array($params)) { | 
					
						
							|  |  |  |             $params = array($params); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $params = array( | 
					
						
							|  |  |  |             'table' => new DbExpr($this->identify($this->table())), | 
					
						
							|  |  |  |             'pk' => new DbExpr($this->identify($this->key)), | 
					
						
							|  |  |  |         ) + $params; | 
					
						
							|  |  |  |         return $this->db->query($sql, $params); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2012-10-19 20:15:26 +04:00
										 |  |  |      * @param string $data Request | 
					
						
							|  |  |  |      * @param array $params Request parameters | 
					
						
							|  |  |  |      * @param string $field Requested field name | 
					
						
							|  |  |  |      * @param CacheKey $cache_key Key for caching in | 
					
						
							|  |  |  |      * @return mixed | 
					
						
							| 
									
										
										
										
											2011-11-11 18:01:17 +04:00
										 |  |  |      */ | 
					
						
							|  |  |  |     protected function fetchField($data, $params = array(), $field, $cache_key = null) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if (!$cache_key || !$result = $cache_key->get()) { | 
					
						
							|  |  |  |             $result = $this->query($data, $params)->fetchField($field); | 
					
						
							|  |  |  |             if ($cache_key) { | 
					
						
							|  |  |  |                 $cache_key->set($result); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         return $result; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2012-10-19 20:15:26 +04:00
										 |  |  |      * @param string $data Request | 
					
						
							|  |  |  |      * @param array $params Request parameters | 
					
						
							|  |  |  |      * @param CacheKey $cache_key Key for caching in | 
					
						
							|  |  |  |      * @return mixed | 
					
						
							| 
									
										
										
										
											2011-11-11 18:01:17 +04:00
										 |  |  |      */ | 
					
						
							|  |  |  |     protected function fetch($data, $params = array(), $cache_key = null) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if (!$cache_key || !$result = $cache_key->get()) { | 
					
						
							|  |  |  |             $result = $this->query($data, $params)->fetch(); | 
					
						
							|  |  |  |             if ($cache_key) { | 
					
						
							|  |  |  |                 $cache_key->set($result); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         return $result; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2012-10-19 20:15:26 +04:00
										 |  |  |      * @param string $data | 
					
						
							| 
									
										
										
										
											2011-11-11 18:01:17 +04:00
										 |  |  |      * @param array $params | 
					
						
							|  |  |  |      * @param CacheKey $cache_key | 
					
						
							| 
									
										
										
										
											2012-10-19 20:15:26 +04:00
										 |  |  |      * @return array | 
					
						
							| 
									
										
										
										
											2011-11-11 18:01:17 +04:00
										 |  |  |      */ | 
					
						
							|  |  |  |     protected function fetchAll($data, $params = array(), $cache_key = null) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if (!$cache_key || !$result = $cache_key->get()) { | 
					
						
							|  |  |  |             $result = $this->query($data, $params)->fetchAll(); | 
					
						
							|  |  |  |             if ($cache_key) { | 
					
						
							|  |  |  |                 $cache_key->set($result); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         return $result; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2013-09-17 09:51:20 +04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-09-20 22:11:54 +04:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param $select array | 
					
						
							|  |  |  |      * @param $distinct string|bool | 
					
						
							|  |  |  |      * @param $where array @ex array('field=?' => $value, 'field=1') | 
					
						
							|  |  |  |      * @param $order array @ex array('sort' => array('field1', 'field2'), 'order' => array('field2' => 'desc')) | 
					
						
							|  |  |  |      * @param $limit string @ex '30' or '30,30' | 
					
						
							|  |  |  |      * @param $heaving TODO | 
					
						
							|  |  |  |      * @param $group_by TODO | 
					
						
							|  |  |  |      * @param $sql_expression null|string | 
					
						
							|  |  |  |      * @param $sql_expression_params array | 
					
						
							|  |  |  |      * @param $cache_key CacheKey|null | 
					
						
							|  |  |  |      * @return SqlResultProvider | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function find($select, $distinct, $where, $order, $limit, $heaving = null, $group_by = null, $sql_expression = null, $sql_expression_params = array(), $cache_key = null) | 
					
						
							| 
									
										
										
										
											2013-09-17 09:51:20 +04:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2013-09-20 22:11:54 +04:00
										 |  |  |         $select = $this->db->selectExpr($select, $distinct); | 
					
						
							|  |  |  |         $where = $this->db->whereExpr($where); | 
					
						
							| 
									
										
										
										
											2013-10-29 16:42:33 +04:00
										 |  |  |         $group_by = $this->db->groupByExpr($group_by); | 
					
						
							| 
									
										
										
										
											2013-09-20 22:11:54 +04:00
										 |  |  |         $order = isset($order['sort']) ? $this->order($order, $order['sort']) : false; | 
					
						
							|  |  |  |         $limit = $this->db->limitExpr($limit); | 
					
						
							| 
									
										
										
										
											2014-03-06 15:26:59 +04:00
										 |  |  |         $result = $this->query( | 
					
						
							| 
									
										
										
										
											2014-05-08 19:12:09 +04:00
										 |  |  |             (($sql_expression) ? $sql_expression : ('SELECT ' . $select . ' FROM ' . $this->identify($this->table()))) | 
					
						
							| 
									
										
										
										
											2013-09-20 22:11:54 +04:00
										 |  |  |                 . (($where) ? (' WHERE ' . $where) : '') | 
					
						
							| 
									
										
										
										
											2013-10-29 16:42:33 +04:00
										 |  |  |                 . (($group_by) ? (' GROUP BY ' . $group_by) : '') | 
					
						
							| 
									
										
										
										
											2013-09-20 22:11:54 +04:00
										 |  |  |                 . (($order) ? ($order) : '') | 
					
						
							|  |  |  |                 . (($limit) ? (' LIMIT ' . $limit) : ''), | 
					
						
							|  |  |  |             $sql_expression_params, | 
					
						
							|  |  |  |             $cache_key | 
					
						
							|  |  |  |         ); | 
					
						
							| 
									
										
										
										
											2014-03-06 15:26:59 +04:00
										 |  |  |         return new SqlResultProvider($result); | 
					
						
							| 
									
										
										
										
											2013-09-17 18:42:04 +04:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-29 15:59:55 +04:00
										 |  |  |     public function count($select_parent_query = 'x.count', $where, $heaving = null, $group_by = null, $sql_expression = null, $sql_expression_params = array(), $cache_key = null) | 
					
						
							| 
									
										
										
										
											2014-07-28 11:50:27 +04:00
										 |  |  |     { | 
					
						
							|  |  |  |         $where = $this->db->whereExpr($where); | 
					
						
							|  |  |  |         $group_by = $this->db->groupByExpr($group_by); | 
					
						
							|  |  |  |         $result = $this->query( | 
					
						
							| 
									
										
										
										
											2015-01-27 17:43:23 +03:00
										 |  |  |             'SELECT (' . | 
					
						
							| 
									
										
										
										
											2014-07-30 20:01:57 +04:00
										 |  |  |             (($sql_expression) ? $sql_expression : ('SELECT * FROM ' . $this->identify($this->table()))) | 
					
						
							| 
									
										
										
										
											2014-07-28 11:50:27 +04:00
										 |  |  |                 . (($where) ? (' WHERE ' . $where) : '') | 
					
						
							| 
									
										
										
										
											2015-01-30 23:52:16 +03:00
										 |  |  |                 . (($group_by) ? (' GROUP BY ' . $group_by) : '') . ' LIMIT 1) AS count', | 
					
						
							| 
									
										
										
										
											2014-07-28 11:50:27 +04:00
										 |  |  |             $sql_expression_params, | 
					
						
							|  |  |  |             $cache_key | 
					
						
							|  |  |  |         ); | 
					
						
							|  |  |  |         return new SqlResultProvider($result); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-09-17 18:42:04 +04:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2013-09-20 22:11:54 +04:00
										 |  |  |      * @param $sql_expression null | 
					
						
							|  |  |  |      * @param $sql_expression_params array | 
					
						
							| 
									
										
										
										
											2013-09-19 10:05:00 +04:00
										 |  |  |      * @return SqlCriteria | 
					
						
							| 
									
										
										
										
											2013-09-17 18:42:04 +04:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2013-09-20 22:11:54 +04:00
										 |  |  |     public function criteria($sql_expression = null, $sql_expression_params = array()) | 
					
						
							| 
									
										
										
										
											2013-09-17 18:42:04 +04:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2013-09-20 22:11:54 +04:00
										 |  |  |         return new SqlCriteria($this, $sql_expression, $sql_expression_params); | 
					
						
							| 
									
										
										
										
											2013-09-17 14:57:56 +04:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2011-11-11 18:01:17 +04:00
										 |  |  | } |