gorm/table_and_query.go
Raul-Mircea 7272b99bd2 Fix
2019-11-14 16:22:44 +02:00

27 lines
574 B
Go

package gorm
import (
"strings"
"time"
)
// TableAndQuery returns the table name and the query already formatted as a string
func (scope *Scope) TableAndQuery() (string, string) {
scope.InstanceSet("skip_bindvar", true)
scope.prepareQuerySQL()
qs := LogFormatter("sql", "q", time.Duration(1), scope.SQL, scope.SQLVars, int64(1))
t, q := scope.TableName(), qs[3].(string)
if t == "" {
qsplit := strings.Fields(strings.ToLower(q))
for i := range qsplit {
if qsplit[i] == "from" && i < len(qsplit)-2 {
t = qsplit[i+1]
break
}
}
}
return t, q
}