gorm/table_and_query.go
Raul-Mircea 30863a092a Fix
2020-01-27 13:48:49 +01:00

29 lines
633 B
Go

package gorm
import (
"strings"
)
// TableAndQuery returns the table name and the query already formatted as a string
func (scope Scope) TableAndQuery() (string, string) {
scope.InstanceSet("skip_bindvar", true)
//qs := LogFormatter("sql", "q", time.Duration(1), scope.SQL, scope.SQLVars, int64(1))
//t, q := scope.TableName(), qs[3].(string)
if scope.SQL == "" {
scope.prepareQuerySQL()
}
t, q := scope.TableName(), scope.SQL
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
}