You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

166 lines
4.3 KiB

  1. <?php
  2. class SqlCriteria
  3. {
  4. private $select = array();
  5. private $distinct = '';
  6. private $where = array();
  7. private $group_by = array();
  8. private $order = array('sort' => array(), 'order' => array());
  9. private $limit = '';
  10. /**
  11. * @var SqlModel
  12. */
  13. private $model;
  14. private $sql_expression;
  15. private $sql_expression_params = array();
  16. /**
  17. * @param $model SqlModel
  18. * @param $sql_expression string|null Sql expression with SELECT and FROM operators. If fetched, then SqlCriteria::select(), SqlCriteria::distinct() disabled for use.
  19. * @param $sql_expression_params array additional params to be replaced in sql expression
  20. */
  21. public function __construct($model, $sql_expression = null, $sql_expression_params = array())
  22. {
  23. $this->model = $model;
  24. $this->sql_expression = $sql_expression;
  25. $this->sql_expression_params = $sql_expression_params;
  26. }
  27. /**
  28. * @return SqlResultProvider
  29. */
  30. public function find()
  31. {
  32. return $this->model->find($this->select, $this->distinct, $this->where, $this->order, $this->limit, null, $this->group_by, $this->sql_expression, $this->sql_expression_params);
  33. }
  34. public function count()
  35. {
  36. return $this->model->find(new DbExpr('COUNT(*) as count'), '', $this->where, null, null, null, null, $this->sql_expression, $this->sql_expression_params)->fetchField('count');
  37. }
  38. /**
  39. * @param $cond string|array Condition with "?" placeholder @ex 'field=?' or 'field=1' or array('field=?' => 1', 'field=1')
  40. * @param $value string|array|DbExpr|null Value. Array transformed to DbExpr(implode(',' Array)) All elements in the array mast be integer
  41. * @return SqlCriteria
  42. * @desc Allow multiple calls
  43. */
  44. public function where($cond, $value = null)
  45. {
  46. if (is_null($value)) {
  47. if (is_array($cond)) {
  48. $this->where = $this->where + $cond;
  49. } else {
  50. $this->where[] = $cond;
  51. }
  52. } else {
  53. $this->where[$cond] = $value;
  54. }
  55. return $this;
  56. }
  57. /**
  58. * @param $field string
  59. * @param $value array
  60. * @return SqlCriteria
  61. */
  62. public function whereIn($field, $value)
  63. {
  64. return $this->where($field . ' in ?', $value);
  65. }
  66. /**
  67. * @param $field string
  68. * @param $value array
  69. * @return SqlCriteria
  70. */
  71. public function whereNotIn($field, $value)
  72. {
  73. return $this->where($field . ' not in ?', $value);
  74. }
  75. /**
  76. * @param $field string
  77. * @param $value array
  78. * @return SqlCriteria
  79. * @deprecated
  80. */
  81. public function whereNot($field, $value)
  82. {
  83. return $this->whereNotIn($field, $value);
  84. }
  85. public function groupBy($fields)
  86. {
  87. if (is_array($fields)) {
  88. $this->group_by = $this->group_by + $fields;
  89. } else {
  90. $this->group_by[] = $fields;
  91. }
  92. return $this;
  93. }
  94. /**
  95. * @param $field string Field @ex 'field'
  96. * @param $order_desc bool Descendant sort direction
  97. * @return SqlCriteria
  98. * @desc Allow multiple calls
  99. */
  100. public function order($field, $order_desc = false)
  101. {
  102. $this->order['sort'][] = $field;
  103. if ($order_desc) {
  104. $this->order['order'][$field] = 'desc';
  105. }
  106. return $this;
  107. }
  108. /**
  109. * @param $offset int
  110. * @param $limit int
  111. * @return SqlCriteria
  112. */
  113. public function limit($offset = 0, $limit)
  114. {
  115. if ($offset) {
  116. $this->limit = (int) $offset . ',';
  117. }
  118. $this->limit .= (int) $limit;
  119. return $this;
  120. }
  121. /**
  122. * @param string|array $fields
  123. * @ex SqlCriteria::select('field')
  124. * @ex SqlCriteria->select(array('field1', 'field2'))
  125. * @ex SqlCriteria->select('field1,field2')
  126. * @return SqlCriteria
  127. */
  128. public function select($fields)
  129. {
  130. if (!is_array($fields)) {
  131. $fields = explode(',', $fields);
  132. }
  133. $fields = array_map(function($item){return trim($item);},$fields);
  134. $this->select = array_merge($this->select,$fields);
  135. return $this;
  136. }
  137. /**
  138. * @param $field string|bool If true then distinct by *
  139. * @return SqlCriteria
  140. */
  141. public function distinct($field)
  142. {
  143. $this->distinct = $field;
  144. return $this;
  145. }
  146. }