【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

相关推荐
MY_TEUCK6 小时前
【Java 后端】SpringBoot 登录认证与会话跟踪实战(JWT + Filter/Interceptor)
java·开发语言·spring boot
QQ2422199796 小时前
基于python+微信小程序的家教管理系统_mh3j9
开发语言·python·微信小程序
沐知全栈开发7 小时前
JavaScript 条件语句
开发语言
RSTJ_16257 小时前
PYTHON+AI LLM DAY THREETY-SEVEN
开发语言·人工智能·python
清水白石0087 小时前
《Python性能深潜:从对象分配开销到“小对象风暴”的破解之道(含实战与最佳实践)》
开发语言·python
Je1lyfish7 小时前
CMU15-445 (2025 Fall/2026 Spring) Project#3 - QueryExecution
linux·c语言·开发语言·数据结构·数据库·c++·算法
Brilliantwxx8 小时前
【C++】 vector(代码实现+坑点讲解)
开发语言·c++·笔记·算法
野生技术架构师8 小时前
2026年最全Java面试题及答案汇总(建议收藏,面试前看这篇就够了)
java·开发语言·面试
百锦再8 小时前
Auto.js变成基础知识学习
开发语言·javascript·学习·sqlite·kotlin·android studio·数据库开发
叼烟扛炮8 小时前
C++第三讲:类和对象(中)
开发语言·c++·类和对象