【golang】mysql默认排序无法实现 使用golang实现对时间字符串字段的排序

一、问题场景

1、mysql实现排序-性能低下

例如:某字段 finish_time 数据如下:6:13:2710:56:1121:56:11

会出现顺序如下的场景: 10:56:1121:56:116:13:27

二、解决方案

2、golang实现排序

go 复制代码
package main

import (
	"fmt"
	"sort"
	"strconv"
	"strings"
)

// 提取小时、分钟和秒部分的函数
func extractHourMinuteSecond(timeStr string) int {
	parts := strings.Split(timeStr, ":")
	if len(parts) >= 3 {
		hour, _ := strconv.Atoi(parts[0])
		minute, _ := strconv.Atoi(parts[1])
		second, _ := strconv.Atoi(parts[2])
		return hour*3600 + minute*60 + second
	}
	return 0
}

func main() {
	// 示例数据,包含两个时间字符串
	time1 := "6:13:27"
	time2 := "10:56:11"
	time3 := "21:56:11"

	// 将示例数据放入切片中
	times := []string{time1, time2, time3}

	// 自定义排序逻辑
	sort.Slice(times, func(i, j int) bool {
		// 提取小时、分钟和秒部分
		timeI := extractHourMinuteSecond(times[i])
		timeJ := extractHourMinuteSecond(times[j])

		// 比较时间值
		return timeI < timeJ
	})

	// 输出排序后的结果
	for _, t := range times {
		fmt.Println(t)
	}
}

输出结果:

6:13:27

10:56:11

21:56:11

相关推荐
方也_arkling2 分钟前
【Java-Day11】抽象类和抽象方法
java·开发语言
Ulyanov9 分钟前
深入QML-Python通信 构建响应式交互界面的桥梁设计:QML+PySide6现代开发入门(五)
开发语言·python·算法·交互·qml·系统仿真
就叫_这个吧11 分钟前
JavaScript中常用事件示例展示附源码
开发语言·javascript·html
不会C语言的男孩13 分钟前
C++ Primer Plus 第9章:内存模型和名称空间
开发语言·c++
zz345729811316 分钟前
函数:python与c语言
c语言·开发语言·python
峥嵘life28 分钟前
Android getprop 属性限制详解:User 版本属性获取问题分析
android·开发语言·python·学习
郝学胜-神的一滴30 分钟前
Qt 高级开发 019:从零定制登录窗口按钮、Logo 样式与交互悬浮效果
开发语言·c++·qt·程序人生·交互·用户界面
星夜夏空9934 分钟前
FreeRTOS学习(5)——内存映射
开发语言·学习
yujunl1 小时前
resx文件上具有 Web 标记
开发语言
catchadmin1 小时前
免费可商用 PHP 管理后台 CatchAdmin V5.3.1 发布 后台打包直降 5s 内
开发语言·php