Files
sqlite3/driver/time.go
2023-02-19 12:44:26 +00:00

34 lines
827 B
Go

package driver
import (
"database/sql/driver"
"time"
)
// Convert a string in [time.RFC3339Nano] format into a [time.Time]
// if it roundtrips back to the same string.
// This way times can be persisted to, and recovered from, the database,
// but if a string is needed, [database.sql] will recover the same string.
func maybeDate(text string) driver.Value {
// Weed out (some) values that can't possibly be
// [time.RFC3339Nano] timestamps.
if len(text) < len("2006-01-02T15:04:05") {
return text
}
if text[4] != '-' || text[10] != 'T' || text[16] != ':' {
return text
}
for _, c := range []byte(text[:4]) {
if c < '0' || '9' < c {
return text
}
}
// Slow path.
date, err := time.Parse(time.RFC3339Nano, text)
if err == nil && date.Format(time.RFC3339Nano) == text {
return date
}
return text
}