summaryrefslogtreecommitdiff
path: root/src/mongo/gotools/mongoimport/dateconv/dateconv.go
blob: 91fecf51ad7b288d88103f12b4181a66d35a71bc (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
package dateconv

import (
	"strings"
)

var (
	// msReplacers based on:
	// https://msdn.microsoft.com/en-us/library/ee634398(v=sql.130).aspx
	msReplacers = []string{
		"dddd", "Monday",
		"ddd", "Mon",
		"dd", "02",
		"d", "2",
		"MMMM", "January",
		"MMM", "Jan",
		"MM", "01",
		"M", "1",
		// "gg", "?",
		"hh", "03",
		"h", "3",
		"HH", "15",
		"H", "15",
		"mm", "04",
		"m", "4",
		"ss", "05",
		"s", "5",
		// "f", "?",
		"tt", "PM",
		// "t", "?",
		"yyyy", "2006",
		"yyy", "2006",
		"yy", "06",
		// "y", "?",
		"zzz", "-07:00",
		"zz", "-07",
		// "z", "?",
	}
	msStringReplacer = strings.NewReplacer(msReplacers...)
)

// FromMS reformats a datetime layout string from the Microsoft SQL Server
// FORMAT function into go's parse format.
func FromMS(layout string) string {
	return msStringReplacer.Replace(layout)
}

var (
	// oracleReplacers based on:
	// http://docs.oracle.com/cd/B19306_01/server.102/b14200/sql_elements004.htm#i34924
	oracleReplacers = []string{
		"AM", "PM",
		"DAY", "Monday",
		"DY", "Mon",
		"DD", "02",
		"HH12", "03",
		"HH24", "15",
		"HH", "03",
		"MI", "04",
		"MONTH", "January",
		"MON", "Jan",
		"MM", "01",
		"SS", "05",
		"TZD", "MST",
		"TZH:TZM", "-07:00",
		"TZH", "-07",
		"YYYY", "2006",
		"YY", "06",
	}
	oracleStringReplacer = strings.NewReplacer(oracleReplacers...)
)

// FromOrace reformats a datetime layout string from the Oracle Database
// TO_DATE function into go's parse format.
func FromOracle(layout string) string {
	return oracleStringReplacer.Replace(strings.ToUpper(layout))
}