2021-06-24 07:43:28 +00:00
|
|
|
package bob
|
|
|
|
|
2021-06-26 02:57:08 +00:00
|
|
|
import (
|
|
|
|
"strconv"
|
|
|
|
"strings"
|
|
|
|
)
|
2021-06-25 17:04:41 +00:00
|
|
|
|
|
|
|
const (
|
2021-06-26 02:57:08 +00:00
|
|
|
// Question is the format used in MySQL
|
2021-06-25 17:04:41 +00:00
|
|
|
Question = "?"
|
2021-06-26 02:57:08 +00:00
|
|
|
// 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
|
|
|
|
2021-06-26 02:57:08 +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
|
|
|
|
2021-06-26 02:57:08 +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
|
|
|
|
}
|
2021-06-26 02:57:08 +00:00
|
|
|
|
|
|
|
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)
|
|
|
|
}
|