bob/placeholder.go

41 lines
1.0 KiB
Go
Raw Normal View History

2021-06-24 07:43:28 +00:00
package bob
import (
"strconv"
"strings"
)
2021-06-25 17:04:41 +00:00
const (
// Question is the format used in MySQL
2021-06-25 17:04:41 +00:00
Question = "?"
// Dollar is the format used in PostgreSQL
Dollar = "$"
// Colon is the format used in Oracle Database, but here I implemented it wrong.
// I will either fix it or remove it in the future.
Colon = ":"
// AtP comes in the documentation of Squirrel but I don't know what database uses it.
AtP = "@p"
2021-06-25 17:04:41 +00:00
)
2021-06-24 07:43:28 +00:00
// PlaceholderFormat is an interface for placeholder formattings.
2021-06-24 07:43:28 +00:00
type PlaceholderFormat interface {
ReplacePlaceholders(sql string) (string, error)
}
2021-06-25 17:04:41 +00:00
// ReplacePlaceholder converts default placeholder format to a specific format.
2021-06-25 17:04:41 +00:00
func ReplacePlaceholder(sql string, format string) string {
if format == "" {
format = Question
}
if format == Dollar || format == Colon {
separate := strings.SplitAfter(sql, "?")
for i := 0; i < len(separate); i++ {
separate[i] = strings.Replace(separate[i], "?", format+strconv.Itoa(i+1), 1)
}
return strings.Join(separate, "")
}
2021-06-25 17:04:41 +00:00
return strings.ReplaceAll(sql, "?", format)
}