golang 计算两个时间相差具体哪几个月

研发过程中遇到需要根据两个时间相差几个月,计算出月份后,联合查询以年月为后缀的数据库表。

例如: 2020-011-11 15:30:30 ~  2021-03-11 15:30:30,需要计算出  2020-11、2020-12、

2021-01、2021-02、2021-03 计算出。

现在提供一个比较low的方法:

func MakeSelectTable(startDate , endDate time.Time, prfix string) string {

	if startDate.Sub(endDate) > 0 {
		return ""
	}
	arr := []string{}
	yearS:= startDate.Year()
	monthS:=int(startDate.Month())
	yearE:=endDate.Year() * 100000
	monthE :=int(endDate.Month())
	i := 0
	for {
		if yearS * 100000 + monthS <= yearE + monthE {
			i = i +1
			arr = append(arr,fmt.Sprintf(prfix+"%d_%02d",yearS,monthS))
			monthS =  monthS + 1
			if monthS > 12 {
				yearS = yearS + 1

				monthS = 1
			}

		}else {
			break
		}
	}
	fmt.Println("arr====",arr)
	if len(arr) > 1 {
		return " ( SELECT * FROM  " + strings.Join(arr, "  UNION SELECT * FROM ") + " ) "
	}else{
		return "SELECT * FROM  " + arr[0]
	}
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值