Files
gocqlx/qb/expr.go

66 lines
1.0 KiB
Go
Raw Normal View History

2017-09-21 21:43:27 +02:00
// Copyright (C) 2017 ScyllaDB
// Use of this source code is governed by a ALv2-style
// license that can be found in the LICENSE file.
2017-07-26 13:57:10 +02:00
package qb
import (
"bytes"
)
type columns []string
2017-07-27 12:28:01 +02:00
func (cols columns) writeCql(cql *bytes.Buffer) {
for i, c := range cols {
cql.WriteString(c)
if i < len(cols)-1 {
cql.WriteByte(',')
}
}
}
2017-07-26 13:57:10 +02:00
type using struct {
2017-08-01 12:44:10 +02:00
timestamp bool
ttl bool
2017-07-26 13:57:10 +02:00
}
2017-08-01 12:44:10 +02:00
func (u using) writeCql(cql *bytes.Buffer) (names []string) {
if u.timestamp {
cql.WriteString("USING TIMESTAMP ? ")
names = append(names, "_ts")
2017-07-26 13:57:10 +02:00
}
2017-07-27 13:39:27 +02:00
2017-08-01 12:44:10 +02:00
if u.ttl {
if u.timestamp {
cql.WriteString("AND TTL ? ")
2017-07-27 13:39:27 +02:00
} else {
2017-08-01 12:44:10 +02:00
cql.WriteString("USING TTL ? ")
2017-07-27 13:39:27 +02:00
}
2017-08-01 12:44:10 +02:00
names = append(names, "_ttl")
2017-07-26 13:57:10 +02:00
}
2017-08-01 12:44:10 +02:00
return
2017-07-26 13:57:10 +02:00
}
2017-07-27 13:39:27 +02:00
type where cmps
func (w where) writeCql(cql *bytes.Buffer) (names []string) {
if len(w) == 0 {
return
}
cql.WriteString("WHERE ")
2017-07-27 13:39:27 +02:00
return cmps(w).writeCql(cql)
}
2017-07-27 13:39:27 +02:00
type _if cmps
func (w _if) writeCql(cql *bytes.Buffer) (names []string) {
if len(w) == 0 {
return
}
cql.WriteString("IF ")
2017-07-27 13:39:27 +02:00
return cmps(w).writeCql(cql)
}