## **在个别业务中需要我们对数据进行排序**
> 例如 我们需要给小说中的栏目进行排序 根据`order`字段 小的在最上面 而且order字段不能重复
不多说 下面就是代码
数据表如下
![](https://img.kancloud.cn/dc/d9/dcd9ac48a1f3d311e76d4d089163d69a_252x272.png)
~~~
//排序 加入需要将 id=1的数据改成5 需要传值 id=1 order=5
public function order(Request $request)
{
$id = $request->id ?? 0; //需要修改的数据ID
$order = $request->order ?? 0; //需要排序的大小
$old_order = DB::table("test")->where('id',$id)->value('order');
//判断数据是调大还是调小 ($order > $old_order 调大) 如果调大则 所有影响的数据 都要调小
if($order > $old_order){
$where = [['order','>',$old_order], ['order','<=',$order]];
$type = 1;
}else{
$where = [['order','>=',$order], ['order','<',$old_order]];
$type = 2;
}
$update_data = $this->_executeOrder($where,$type);
foreach ($update_data as $value){
DB::table("test")->where('id',$value->id)->update(['order' => $value->add_order]);
}
DB::table("test")->where('id',$id)->update(['order' => $order]);
}
//处理受影响的数据
public function _executeOrder($where,$type)
{
$update_data = DB::table("test")->where($where)->get();
foreach ($update_data as &$value){
if($type == 1){
$value->add_order = $value->order - 1;
}else{
$value->add_order = $value->order + 1;
}
}
return $update_data;
}
~~~
![](https://img.kancloud.cn/cd/2e/cd2e9608c4c78331c7f5f34bd94ca549_540x341.png)
* 注意 以上代码为laravel框架 其他框架可根据情况做适当修改
## 原生排序
~~~
class MLQuickSort{
/**
* Name 小值变大值
* Created by WML
* Created on 2021/12/24
* @param array $old
* @param array $new
* @param array $arr
* @return array
*/
static function minToMax($old=[],$new=[],$arr=[])
{
$keep = [];
foreach ($arr as $value){
if($value['id'] == $old['id']){
$keep[] = ['id' => $value['id'],'order' => $new['order']];
}
if(($value['order'] <= $new['order']) && ($value['order']) >= $old['order']){
if($value['id'] == $old['id']) continue;
$new_order = $value['order'] - 1;
$keep[] = ['id' => $value['id'],'order' => $new_order];
}else{
$keep[] = $value;
}
}
return $keep;
}
//大值变小值
static function maxToMin($old=[],$new=[],$arr=[])
{
$keep = [];
foreach ($arr as $value){
if($value['id'] == $old['id']){
$keep[] = ['id' => $value['id'],'order' => $new['order']];
}
if(($value['order'] >= $new['order']) && ($value['order']) <= $old['order']){
if($value['id'] == $old['id']) continue;
$new_order = $value['order'] + 1;
$keep[] = ['id' => $value['id'],'order' => $new_order];
}else{
$keep[] = $value;
}
}
return $keep;
}
}
//$arr = [
// ['id' => 1,'order' => 1],
// ['id' => 2,'order' => 2],
// ['id' => 3,'order' => 3],
// ['id' => 4,'order' => 4],
// ['id' => 5,'order' => 5],
//];
//return (new QuickSort)->minToMax(['id' => 1,'order' => 1],['id' => 1,'order' => 3],$arr);
//结果 :
//['id' => 1,'order' => 3]
//['id' => 2,'order' => 1]
//['id' => 3,'order' => 2]
//['id' => 4,'order' => 4]
//['id' => 5,'order' => 5]
//return (new QuickSort)->maxToMin(['id' => 4,'order' => 4],['id' => 4,'order' => 2],$arr);
//结果 :
/*array(5) {
[0]=>
array(2) {
["id"]=>
int(1)
["order"]=>
int(1)
}
[1]=>
array(2) {
["id"]=>
int(2)
["order"]=>
int(3)
}
[2]=>
array(2) {
["id"]=>
int(3)
["order"]=>
int(4)
}
[3]=>
array(2) {
["id"]=>
int(4)
["order"]=>
int(2)
}
[4]=>
array(2) {
["id"]=>
int(5)
["order"]=>
int(5)
}
}*/
~~~
- 文档说明
- 开始
- linux
- 常用命令
- ps -ef
- lsof
- netstat
- 解压缩
- 复制
- 权限
- 其他
- lnmp集成安装
- supervisor
- 安装
- supervisor进程管理
- nginx
- 域名映射
- 负载均衡配置
- lnmp集成环境安装
- nginx源码安装
- location匹配
- 限流配置
- 日志配置
- 重定向配置
- 压缩策略
- nginx 正/反向代理
- HTTPS配置
- mysql
- navicat创建索引
- 设置外网链接mysql
- navicat破解
- sql语句学习
- 新建mysql用户并赋予权限
- php
- opcache
- 设计模式
- 在CentOS下安装crontab服务
- composer
- 基础
- 常用的包
- guzzle
- 二维码
- 公共方法
- 敏感词过滤
- IP访问频次限制
- CURL
- 支付
- 常用递归
- 数据排序
- 图片相关操作
- 权重分配
- 毫秒时间戳
- base64<=>图片
- 身份证号分析
- 手机号相关操作
- 项目搭建 公共处理函数
- JWT
- 系统函数
- json_encode / json_decode 相关
- 数字计算
- 数组排序
- php8
- jit特性
- php8源码编译安装
- laravel框架
- 常用artisan命令
- 常用查询
- 模型关联
- 创建公共方法
- 图片上传
- 中间件
- 路由配置
- jwt
- 队列
- 定时任务
- 日志模块
- laravel+swoole基本使用
- 拓展库
- 请求接口log
- laravel_octane
- 微信开发
- token配置验证
- easywechart 获取用户信息
- 三方包
- webman
- win下热更新代码
- 使用laravel db listen 监听sql语句
- guzzle
- 使用workman的httpCLient
- 修改队列后代码不生效
- workman
- 安装与使用
- websocket
- eleticsearch
- php-es 安装配置
- hyperf
- 热更新
- 安装报错
- swoole
- 安装
- win安装swoole-cli
- google登录
- golang
- 文档地址
- 标准库
- time
- 数据类型
- 基本数据类型
- 复合数据类型
- 协程&管道
- 协程基本使用
- 读写锁 RWMutex
- 互斥锁Mutex
- 管道的基本使用
- 管道select多路复用
- 协程加管道
- beego
- gin
- 安装
- 热更新
- 路由
- 中间件
- 控制器
- 模型
- 配置文件/conf
- gorm
- 初始化
- 控制器 模型查询封装
- 添加
- 修改
- 删除
- 联表查询
- 环境搭建
- Windows
- linux
- 全局异常捕捉
- javascript
- 常用函数
- vue
- vue-cli
- 生产环境 开发环境配置
- 组件通信
- 组件之间通信
- 父传子
- 子传父
- provide->inject (非父子)
- 引用元素和组件
- vue-原始写法
- template基本用法
- vue3+ts项目搭建
- vue3引入element-plus
- axios 封装网络请求
- computed 计算属性
- watch 监听
- 使用@符 代替文件引入路径
- vue开发中常用的插件
- vue 富文本编辑
- nuxt
- 学习笔记
- 新建项目踩坑整理
- css
- flex布局
- flex PC端基本布局
- flex 移动端基本布局
- 常用css属性
- 盒子模型与定位
- 小说分屏显示
- git
- 基本命令
- fetch
- 常用命令
- 每次都需要验证
- git pull 有冲突时
- .gitignore 修改后不生效
- 原理解析
- tcp与udp详解
- TCP三次握手四次挥手
- 缓存雪崩 穿透 更新详解
- 内存泄漏-内存溢出
- php_fpm fast_cgi cig
- redis
- 相关三方文章
- API对外接口文档示范
- elaticsearch
- 全文检索
- 简介
- 安装
- kibana
- 核心概念 索引 映射 文档
- 高级查询 Query DSL
- 索引原理
- 分词器
- 过滤查询
- 聚合查询
- 整合应用
- 集群
- docker
- docker 简介
- docker 安装
- docker 常用命令
- image 镜像命令
- Contrainer 容器命令
- docker-compose
- redis 相关
- 客户端安装
- Linux 环境下安装
- uni
- http请求封装
- ios打包
- 视频纵向播放
- 日记
- 工作日记
- 情感日志
- 压测
- ab
- ui
- thorui
- 开发规范
- 前端
- 后端
- 状态码
- 开发小组未来规划