mysql PHP:使用选定的起始点和初始化的起始点值重新排序显示顺序

sqyvllje  于 11个月前  发布在  Mysql
关注(0)|答案(1)|浏览(144)

刚刚参加了一个总结性的面试,面试官给我分配了一个涉及CRUD操作的任务。该任务特别需要显示按“display_order”列排序的数据。在表列表中,有一个复选框允许用户重新排列顺序。要这样做,必须选中该复选框并指定显示顺序的起始点。例如:
示例:起点:2
原始列表:
| ID|显示顺序|复选框|
| --|--|--|
| 69 | 1 ||
| 71 | 2 ||
| 37 | 3 ||
| 52 | 4 ||
| 59 | 5 ||
| 60 | 6 ||
| 86 | 7 |检查|
| 84 | 8 ||
| 77 | 9 |检查|
| 44 | 10 |检查|
预期结果:
| ID|显示顺序|复选框|
| --|--|--|
| 69 | 1 ||
| 86 | 2 ||
| 77 | 3 ||
| 44 | 4 ||
| 71 | 5 ||
| 37 | 6 ||
| 52 | 7 ||
| 59 | 8 ||
| 60 | 9 ||
| 84 | 10 ||
结果:

[
  {
    "id": "69",
    "sort": 1
  },
  {
    "id": "86",
    "sort": "2"
  },
  {
    "id": "77",
    "sort": "3"
  },
  {
    "id": "44",
    "sort": "4"
  },
  {
    "id": "52",
    "sort": 5
  },
  {
    "id": "71",
    "sort": 5
  },
  {
    "id": "37",
    "sort": 5
  },
  {
    "id": "59",
    "sort": "5"
  },
  {
    "id": "60",
    "sort": "6"
  },
  {
    "id": "84",
    "sort": "8"
  }
]

字符串
另一个例子:起点:8
预期结果:
| ID|显示顺序|复选框|
| --|--|--|
| 69 | 1 ||
| 71 | 2 ||
| 37 | 3 ||
| 52 | 4 ||
| 59 | 5 ||
| 60 | 6 ||
| 84 | 7 ||
| 86 | 8 ||
| 77 | 9 ||
| 44 | 10 ||
结果:

[
  {
    "id": "69",
    "sort": 1
  },
  {
    "id": "71",
    "sort": 2
  },
  {
    "id": "37",
    "sort": 3
  },
  {
    "id": "52",
    "sort": 4
  },
  {
    "id": "59",
    "sort": 5
  },
  {
    "id": "60",
    "sort": 6
  },
  {
    "id": "86",
    "sort": "8"
  },
  {
    "id": "77",
    "sort": "9"
  },
  {
    "id": "44",
    "sort": "10"
  },
  {
    "id": "84",
    "sort": 11
  }
]


下面是我到目前为止的代码:

public function reorder_list($request, $model = 'talk_news') {
    $inputted_display_order = 7;

    if (isset($request['sortable']) && $request['sortable']) {
        $this->setOrm(ORM::for_table($model));
        $sorted_ids = array_column($request['sortable'], 'id');
        $sorted_display_order = array_column($request['sortable'], 'sort');
        $first_display_order = reset($sorted_display_order);
        $last_display_order = end($sorted_display_order);
        $new_order = [];

        $query = $this->_orm->select('id')
            ->select('display_order')
            ->where_not_in('id', $sorted_ids)
            ->order_by_asc('display_order')
            ->find_array();

        $starting_display_order = $first_display_order == 1 ? count($sorted_display_order) + 1 : 1;

        foreach($query as $item) {
            $id = $item['id'];
            $display_order = $item['display_order'];

            $sort_value = $starting_display_order++;

            if ($display_order > $last_display_order && $first_display_order != 1) {
                $sort_value = $display_order;
            }

            if($display_order >= min($sorted_display_order) && $display_order <= max($sorted_display_order) && $first_display_order != 1) {
                $count_to_max = (max($sorted_display_order) + 1) - $display_order;
                $sort_value = $display_order + $count_to_max;
            }

            $new_order[] = [
                'id'   => $id,
                'sort' => $sort_value
            ];
        }

        $new_order = array_merge($new_order, $request['sortable']);

        usort($new_order, function ($a, $b) {
            return $a['sort'] - $b['sort'];
        });

        return $new_order;
    }
}


为了复制这一点,我将提供来自查询和$request ['sortable']的数据:
$query的示例数据:

[{"id":"69","display_order":"1"},{"id":"71","display_order":"2"},{"id":"37","display_order":"3"},{"id":"52","display_order":"4"},{"id":"59","display_order":"5"},{"id":"60","display_order":"6"},{"id":"84","display_order":"8"},{"id":"74","display_order":"11"},{"id":"64","display_order":"12"},{"id":"25","display_order":"13"},{"id":"70","display_order":"14"},{"id":"73","display_order":"15"},{"id":"68","display_order":"16"},{"id":"38","display_order":"17"},{"id":"26","display_order":"18"},{"id":"5","display_order":"19"},{"id":"33","display_order":"20"},{"id":"41","display_order":"21"},{"id":"40","display_order":"22"},{"id":"55","display_order":"23"},{"id":"57","display_order":"24"},{"id":"61","display_order":"25"},{"id":"65","display_order":"26"},{"id":"66","display_order":"27"},{"id":"67","display_order":"28"},{"id":"46","display_order":"29"},{"id":"76","display_order":"30"},{"id":"78","display_order":"31"},{"id":"79","display_order":"32"},{"id":"81","display_order":"33"}]


$request“sortable”的示例数据]

[{"id":"86","sort":"2"},{"id":"77","sort":"3"},{"id":"44","sort":"4"}]

lymnna71

lymnna711#

你可以重新索引$request['sortable'],这样你就有了一个由sort索引的id s数组。然后,对于每个显示顺序,如果存在,从重新索引的数组中获取id,否则array_shift()$query开始的下一个项目。
类似于:

public function reorder_list($request, $model = 'talk_news') {

    if (isset($request['sortable']) && $request['sortable']) {
        $this->setOrm(ORM::for_table($model));
        $sorted_ids = array_column($request['sortable'], 'id');

        /* create array of ids indexed by sort */
        $sorted_display_order = array_column($request['sortable'], 'id', 'sort');

        $new_order = [];

        $query = $this->_orm->select('id')
            ->select('display_order')
            ->where_not_in('id', $sorted_ids)
            ->order_by_asc('display_order')
            ->find_array();

        $total_count = count($query) + count($sorted_ids);

        for ($i = 1; $i <= $total_count; $i++) {
            if (array_key_exists($i, $sorted_display_order)) {
                $id = $sorted_display_order[$i];
            } else {
                $id = array_shift($query)['id'];
            }
            $new_order[] = ['id' => $id, 'sort' => $i];
        }

        return $new_order;
    }
}

字符串

相关问题