dal/pkg/filters/NotBetween.go

27 lines
619 B
Go
Raw Permalink Normal View History

package filters
import (
"fmt"
"l12.xyz/x/dal/pkg/utils"
)
type NotBetween struct {
NotBetween []interface{} `json:"$nbetween"`
}
2024-08-08 17:26:29 +00:00
func (f NotBetween) FromJSON(data interface{}) IFilter {
return FromJson[NotBetween](data)
}
func (f NotBetween) ToSQLPart(ctx Dialect) (string, Values) {
if f.NotBetween == nil {
return "", nil
}
name := ctx.GetFieldName()
values := utils.Map(f.NotBetween, ctx.NormalizeValue)
placeholders := utils.Map(values, ValueOrPlaceholder)
condition := fmt.Sprintf("%s AND %s", placeholders[0], placeholders[1])
return fmt.Sprintf("%s NOT BETWEEN %v", name, condition), values
}