jet/sqlbuilder/expression_old.go

60 lines
1.4 KiB
Go
Raw Normal View History

2019-03-31 09:17:28 +02:00
// Query building functions for expression components
package sqlbuilder
import (
"strconv"
"strings"
"time"
)
type intervalExpression struct {
expressionInterfaceImpl
duration time.Duration
}
2019-05-06 14:01:50 +02:00
const intervalSep = ":"
2019-03-31 09:17:28 +02:00
func (c *intervalExpression) Serialize(out *queryData, options ...serializeOption) error {
out.WriteString("INTERVAL '")
2019-05-06 14:01:50 +02:00
duration := c.duration
if duration < 0 {
duration = -duration
out.WriteString("-")
2019-03-31 09:17:28 +02:00
}
2019-05-06 14:01:50 +02:00
hours := duration / time.Hour
minutes := (duration % time.Hour) / time.Minute
sec := (duration % time.Minute) / time.Second
msec := (duration % time.Second) / time.Microsecond
out.WriteString(strconv.FormatInt(int64(hours), 10))
out.WriteString(intervalSep)
out.WriteString(strconv.FormatInt(int64(minutes), 10))
out.WriteString(intervalSep)
out.WriteString(strconv.FormatInt(int64(sec), 10))
out.WriteString(intervalSep)
out.WriteString(strconv.FormatInt(int64(msec), 10))
out.WriteString("' HOUR_MICROSECOND")
2019-03-31 09:17:28 +02:00
return nil
}
2019-05-06 14:01:50 +02:00
//// Interval returns a representation of duration
//func Interval(duration time.Duration) Expression {
// intervalExp := &intervalExpression{
// duration: duration,
// }
//
// intervalExp.expressionInterfaceImpl.parent = intervalExp
//
// return intervalExp
//}
2019-03-31 09:17:28 +02:00
var likeEscaper = strings.NewReplacer("_", "\\_", "%", "\\%")
func EscapeForLike(s string) string {
return likeEscaper.Replace(s)
}