forked from mirror/gorm
support scan assign slice cap (#5634)
* support scan assign slice cap * fix
This commit is contained in:
parent
5ed7b1a65e
commit
1f634c3937
8
scan.go
8
scan.go
|
@ -248,7 +248,13 @@ func Scan(rows Rows, db *DB, mode ScanMode) {
|
|||
|
||||
if !update || reflectValue.Len() == 0 {
|
||||
update = false
|
||||
db.Statement.ReflectValue.Set(reflect.MakeSlice(reflectValue.Type(), 0, 20))
|
||||
// if the slice cap is externally initialized, the externally initialized slice is directly used here
|
||||
if reflectValue.Cap() == 0 {
|
||||
db.Statement.ReflectValue.Set(reflect.MakeSlice(reflectValue.Type(), 0, 20))
|
||||
} else {
|
||||
reflectValue.SetLen(0)
|
||||
db.Statement.ReflectValue.Set(reflectValue)
|
||||
}
|
||||
}
|
||||
|
||||
for initialized || rows.Next() {
|
||||
|
|
Loading…
Reference in New Issue