forked from mirror/gorm
Fix Select with digits in column name
This commit is contained in:
parent
1305f637f8
commit
a70af2a4c0
|
@ -650,7 +650,7 @@ func (stmt *Statement) Changed(fields ...string) bool {
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
|
|
||||||
var nameMatcher = regexp.MustCompile(`^[\W]?(?:[a-z_]+?)[\W]?\.[\W]?([a-z_]+?)[\W]?$`)
|
var nameMatcher = regexp.MustCompile(`^[\W]?(?:[a-z_0-9]+?)[\W]?\.[\W]?([a-z_0-9]+?)[\W]?$`)
|
||||||
|
|
||||||
// SelectAndOmitColumns get select and omit columns, select -> true, omit -> false
|
// SelectAndOmitColumns get select and omit columns, select -> true, omit -> false
|
||||||
func (stmt *Statement) SelectAndOmitColumns(requireCreate, requireUpdate bool) (map[string]bool, bool) {
|
func (stmt *Statement) SelectAndOmitColumns(requireCreate, requireUpdate bool) (map[string]bool, bool) {
|
||||||
|
|
|
@ -37,10 +37,14 @@ func TestWhereCloneCorruption(t *testing.T) {
|
||||||
|
|
||||||
func TestNameMatcher(t *testing.T) {
|
func TestNameMatcher(t *testing.T) {
|
||||||
for k, v := range map[string]string{
|
for k, v := range map[string]string{
|
||||||
"table.name": "name",
|
"table.name": "name",
|
||||||
"`table`.`name`": "name",
|
"`table`.`name`": "name",
|
||||||
"'table'.'name'": "name",
|
"'table'.'name'": "name",
|
||||||
"'table'.name": "name",
|
"'table'.name": "name",
|
||||||
|
"table1.name_23": "name_23",
|
||||||
|
"`table_1`.`name23`": "name23",
|
||||||
|
"'table23'.'name_1'": "name_1",
|
||||||
|
"'table23'.name1": "name1",
|
||||||
} {
|
} {
|
||||||
if matches := nameMatcher.FindStringSubmatch(k); len(matches) < 2 || matches[1] != v {
|
if matches := nameMatcher.FindStringSubmatch(k); len(matches) < 2 || matches[1] != v {
|
||||||
t.Errorf("failed to match value: %v, got %v, expect: %v", k, matches, v)
|
t.Errorf("failed to match value: %v, got %v, expect: %v", k, matches, v)
|
||||||
|
|
Loading…
Reference in New Issue