2021-08-25 14:34:33 +01:00
|
|
|
package schema
|
|
|
|
|
2021-10-24 12:14:37 +01:00
|
|
|
import (
|
|
|
|
"strings"
|
|
|
|
|
|
|
|
"github.com/uptrace/bun/internal"
|
|
|
|
)
|
|
|
|
|
2021-08-25 14:34:33 +01:00
|
|
|
type QueryAppender interface {
|
|
|
|
AppendQuery(fmter Formatter, b []byte) ([]byte, error)
|
|
|
|
}
|
|
|
|
|
|
|
|
type ColumnsAppender interface {
|
|
|
|
AppendColumns(fmter Formatter, b []byte) ([]byte, error)
|
|
|
|
}
|
|
|
|
|
|
|
|
//------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
// Safe represents a safe SQL query.
|
|
|
|
type Safe string
|
|
|
|
|
|
|
|
var _ QueryAppender = (*Safe)(nil)
|
|
|
|
|
|
|
|
func (s Safe) AppendQuery(fmter Formatter, b []byte) ([]byte, error) {
|
|
|
|
return append(b, s...), nil
|
|
|
|
}
|
|
|
|
|
|
|
|
//------------------------------------------------------------------------------
|
|
|
|
|
2023-09-11 14:16:52 +01:00
|
|
|
// Name represents a single SQL name, for example, a column name.
|
|
|
|
type Name string
|
|
|
|
|
|
|
|
var _ QueryAppender = (*Name)(nil)
|
|
|
|
|
|
|
|
func (s Name) AppendQuery(fmter Formatter, b []byte) ([]byte, error) {
|
|
|
|
return fmter.AppendName(b, string(s)), nil
|
|
|
|
}
|
|
|
|
|
|
|
|
//------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
// Ident represents a SQL identifier, for example,
|
|
|
|
// a fully qualified column name such as `table_name.col_name`.
|
2021-08-25 14:34:33 +01:00
|
|
|
type Ident string
|
|
|
|
|
|
|
|
var _ QueryAppender = (*Ident)(nil)
|
|
|
|
|
|
|
|
func (s Ident) AppendQuery(fmter Formatter, b []byte) ([]byte, error) {
|
|
|
|
return fmter.AppendIdent(b, string(s)), nil
|
|
|
|
}
|
|
|
|
|
|
|
|
//------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
type QueryWithArgs struct {
|
|
|
|
Query string
|
|
|
|
Args []interface{}
|
|
|
|
}
|
|
|
|
|
|
|
|
var _ QueryAppender = QueryWithArgs{}
|
|
|
|
|
|
|
|
func SafeQuery(query string, args []interface{}) QueryWithArgs {
|
2021-09-08 20:05:26 +01:00
|
|
|
if args == nil {
|
2021-08-25 14:34:33 +01:00
|
|
|
args = make([]interface{}, 0)
|
2021-10-24 12:14:37 +01:00
|
|
|
} else if len(query) > 0 && strings.IndexByte(query, '?') == -1 {
|
2022-04-24 11:26:22 +01:00
|
|
|
internal.Warn.Printf("query %q has %v args, but no placeholders", query, args)
|
2021-10-24 12:14:37 +01:00
|
|
|
}
|
|
|
|
return QueryWithArgs{
|
|
|
|
Query: query,
|
|
|
|
Args: args,
|
2021-08-25 14:34:33 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func UnsafeIdent(ident string) QueryWithArgs {
|
|
|
|
return QueryWithArgs{Query: ident}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (q QueryWithArgs) IsZero() bool {
|
|
|
|
return q.Query == "" && q.Args == nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (q QueryWithArgs) AppendQuery(fmter Formatter, b []byte) ([]byte, error) {
|
|
|
|
if q.Args == nil {
|
|
|
|
return fmter.AppendIdent(b, q.Query), nil
|
|
|
|
}
|
|
|
|
return fmter.AppendQuery(b, q.Query, q.Args...), nil
|
|
|
|
}
|
|
|
|
|
|
|
|
//------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
type QueryWithSep struct {
|
|
|
|
QueryWithArgs
|
|
|
|
Sep string
|
|
|
|
}
|
|
|
|
|
|
|
|
func SafeQueryWithSep(query string, args []interface{}, sep string) QueryWithSep {
|
|
|
|
return QueryWithSep{
|
|
|
|
QueryWithArgs: SafeQuery(query, args),
|
|
|
|
Sep: sep,
|
|
|
|
}
|
|
|
|
}
|