Fix NamedArguments with nested struct, close #3596
This commit is contained in:
		
							parent
							
								
									689d6e2331
								
							
						
					
					
						commit
						08ecef8e0b
					
				| @ -91,16 +91,25 @@ func (expr NamedExpr) Build(builder Builder) { | ||||
| 				namedMap[k] = v | ||||
| 			} | ||||
| 		default: | ||||
| 			reflectValue := reflect.Indirect(reflect.ValueOf(value)) | ||||
| 			switch reflectValue.Kind() { | ||||
| 			case reflect.Struct: | ||||
| 				modelType := reflectValue.Type() | ||||
| 				for i := 0; i < modelType.NumField(); i++ { | ||||
| 					if fieldStruct := modelType.Field(i); ast.IsExported(fieldStruct.Name) { | ||||
| 						namedMap[fieldStruct.Name] = reflectValue.Field(i).Interface() | ||||
| 			var appendFieldsToMap func(reflect.Value) | ||||
| 			appendFieldsToMap = func(reflectValue reflect.Value) { | ||||
| 				reflectValue = reflect.Indirect(reflectValue) | ||||
| 				switch reflectValue.Kind() { | ||||
| 				case reflect.Struct: | ||||
| 					modelType := reflectValue.Type() | ||||
| 					for i := 0; i < modelType.NumField(); i++ { | ||||
| 						if fieldStruct := modelType.Field(i); ast.IsExported(fieldStruct.Name) { | ||||
| 							namedMap[fieldStruct.Name] = reflectValue.Field(i).Interface() | ||||
| 
 | ||||
| 							if fieldStruct.Anonymous { | ||||
| 								appendFieldsToMap(reflectValue.Field(i)) | ||||
| 							} | ||||
| 						} | ||||
| 					} | ||||
| 				} | ||||
| 			} | ||||
| 
 | ||||
| 			appendFieldsToMap(reflect.ValueOf(value)) | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
|  | ||||
| @ -37,9 +37,13 @@ func TestExpr(t *testing.T) { | ||||
| } | ||||
| 
 | ||||
| func TestNamedExpr(t *testing.T) { | ||||
| 	type Base struct { | ||||
| 		Name2 string | ||||
| 	} | ||||
| 
 | ||||
| 	type NamedArgument struct { | ||||
| 		Name1 string | ||||
| 		Name2 string | ||||
| 		Base | ||||
| 	} | ||||
| 
 | ||||
| 	results := []struct { | ||||
| @ -73,7 +77,7 @@ func TestNamedExpr(t *testing.T) { | ||||
| 		ExpectedVars: []interface{}{"jinzhu", "jinzhu2", "jinzhu", nil}, | ||||
| 	}, { | ||||
| 		SQL:          "@@test AND name1 = @Name1 AND name2 = @Name2 AND name3 = @Name1 @Notexist", | ||||
| 		Vars:         []interface{}{NamedArgument{Name1: "jinzhu", Name2: "jinzhu2"}}, | ||||
| 		Vars:         []interface{}{NamedArgument{Name1: "jinzhu", Base: Base{Name2: "jinzhu2"}}}, | ||||
| 		Result:       "@@test AND name1 = ? AND name2 = ? AND name3 = ? ?", | ||||
| 		ExpectedVars: []interface{}{"jinzhu", "jinzhu2", "jinzhu", nil}, | ||||
| 	}, { | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Jinzhu
						Jinzhu