ipbl/vendor/xorm.io/xorm/dialects/time.go

64 lines
1.5 KiB
Go
Raw Normal View History

2021-11-07 20:44:48 +01:00
// Copyright 2015 The Xorm Authors. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
package dialects
import (
"strings"
"time"
"xorm.io/xorm/schemas"
)
// FormatColumnTime format column time
func FormatColumnTime(dialect Dialect, dbLocation *time.Location, col *schemas.Column, t time.Time) (interface{}, error) {
if t.IsZero() {
if col.Nullable {
return nil, nil
}
if col.SQLType.IsNumeric() {
return 0, nil
}
}
2023-01-14 13:28:44 +01:00
tmZone := dbLocation
2021-11-07 20:44:48 +01:00
if col.TimeZone != nil {
tmZone = col.TimeZone
}
t = t.In(tmZone)
switch col.SQLType.Name {
case schemas.Date:
return t.Format("2006-01-02"), nil
case schemas.Time:
2023-01-14 13:28:44 +01:00
layout := "15:04:05"
2021-11-07 20:44:48 +01:00
if col.Length > 0 {
2023-01-14 13:28:44 +01:00
// we can use int(...) casting here as it's very unlikely to a huge sized field
layout += "." + strings.Repeat("0", int(col.Length))
2021-11-07 20:44:48 +01:00
}
return t.Format(layout), nil
case schemas.DateTime, schemas.TimeStamp:
2023-01-14 13:28:44 +01:00
layout := "2006-01-02 15:04:05"
2021-11-07 20:44:48 +01:00
if col.Length > 0 {
2023-01-14 13:28:44 +01:00
// we can use int(...) casting here as it's very unlikely to a huge sized field
layout += "." + strings.Repeat("0", int(col.Length))
2021-11-07 20:44:48 +01:00
}
return t.Format(layout), nil
case schemas.Varchar:
return t.Format("2006-01-02 15:04:05"), nil
case schemas.TimeStampz:
if dialect.URI().DBType == schemas.MSSQL {
return t.Format("2006-01-02T15:04:05.9999999Z07:00"), nil
} else {
return t.Format(time.RFC3339Nano), nil
}
case schemas.BigInt, schemas.Int:
return t.Unix(), nil
default:
return t, nil
}
}