QueryService.php 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130
  1. <?php
  2. namespace App\Services\common;
  3. use Carbon\Carbon;
  4. use App\Traits\ServiceAppAop;
  5. use Illuminate\Database\Eloquent\Builder;
  6. class QueryService
  7. {
  8. use ServiceAppAop;
  9. protected $modelClass=Query::class;
  10. /**
  11. * parameter - query(sql) - special column description
  12. *
  13. * @param array $params
  14. * @param object $query
  15. * @param array $columnQueryRules
  16. * @param string $tableName
  17. * @return object
  18. */
  19. public function query(array $params,$query,array $columnQueryRules,$tableName = null)
  20. {
  21. if ($tableName) $tableName .= ".";
  22. foreach ($params as $param => $value){
  23. if ($param === 'paginate' || $param === 'page')continue;
  24. if (!$value || ($columnQueryRules[$param] ?? false))continue;
  25. $query = $query->where($tableName.$param,$value);
  26. }
  27. //rules: alias timeLimit startDate endDate like multi
  28. foreach ($columnQueryRules as $param => $rules){
  29. if (!($params[$param] ?? false) || !$params[$param])continue;
  30. $isExecute = true;
  31. $column = $param;
  32. foreach ($rules as $rule => $value){
  33. if ($rule === 'alias'){
  34. $column = $value;
  35. $isExecute = false;
  36. }
  37. if ($rule === 'timeLimit'){
  38. $today=Carbon::now()->subDays($value);
  39. $queryTemp=clone $query;
  40. $queryTemp=$queryTemp->where($tableName.$column,'like','%'.$params[$param].'%')
  41. ->where($tableName.'created_at','>',$today);
  42. if($queryTemp->count()==0 || $queryTemp->first()[$column]==$params[$param]){
  43. $query=$query->where($tableName.$column,"like",$params[$param]."%");
  44. }else{
  45. $query=$query->where($tableName.$column,'like','%'.$params[$param].'%')
  46. ->where($tableName.'created_at','>',$today);
  47. }
  48. $isExecute = true;
  49. }
  50. if ($rule === 'startDate'){
  51. $startDate = $params[$param].$value;
  52. $query = $query->where($tableName.$column,'>=',$startDate);
  53. $isExecute = true;
  54. }
  55. if ($rule === 'endDate'){
  56. $endDate = $params[$param].$value;
  57. $query = $query->where($tableName.$column,'<=',$endDate);
  58. $isExecute = true;
  59. }
  60. if ($rule === 'like'){
  61. $query = $query->where($tableName.$column,'like',$value.$params[$param].$value.'%');
  62. $isExecute = true;
  63. }
  64. if ($rule === 'multi'){
  65. $query = $query->whereIn($tableName.$column,explode($value,$params[$param]));
  66. $isExecute = true;
  67. }
  68. if ($rule === 'batch'){
  69. if (strpos($value.$params[$param].$value, ',') || strpos($value.$params[$param].$value, ',') || strpos($value.$params[$param].$value, ' ')) {
  70. $arr = array_filter(preg_split('/[,, ]+/is', $value.$params[$param].$value));
  71. $query = $query->whereIn($tableName.$column, $arr);
  72. } else {
  73. $query = $query->where($tableName.$column,'like',$value.$params[$param].$value.'%');
  74. }
  75. $isExecute = true;
  76. }
  77. }
  78. if (!$isExecute) $query = $query->where($tableName.$column,$params[$param]);
  79. }
  80. return $query;
  81. }
  82. public function priceModelAuditOrRecoverQuery($isAudit, Builder $query, $ownerId, $ids, $notRelation = false)
  83. {
  84. $query = $query->whereNotNull("operation")->where("operation","!=","");
  85. if ($ownerId){
  86. if ($notRelation){
  87. if (is_array($ownerId))$query->whereIn("owner_id",$ownerId);
  88. else $query->where("owner_id",$ownerId);
  89. }else{
  90. $query->whereHas("owners",function ($query)use($ownerId){
  91. /** @var Builder $query */
  92. if (is_array($ownerId))$query->whereIn("id",$ownerId);
  93. else $query->where("id",$ownerId);
  94. });
  95. }
  96. }
  97. if ($ids){
  98. if (is_array($ids))$query->whereIn("id",$ids);
  99. else $query->where("id",$ids);
  100. }
  101. $delete = [];
  102. $update = [];
  103. if ($isAudit){
  104. foreach ($query->get() as $model){
  105. if ($model->operation == "D"){
  106. $delete[] = $model->id;
  107. continue;
  108. }
  109. if ($model->operation == "U" && $model->target_id)$delete[] = $model->target_id;
  110. $update[] = $model->id;
  111. }
  112. }else{
  113. foreach ($query->get() as $model){
  114. if ($model->operation == "D"){
  115. $update[] = $model->id;
  116. continue;
  117. }
  118. $delete[] = $model->id;
  119. }
  120. }
  121. return ["delete"=>$delete,"update"=>$update];
  122. }
  123. }