readRows scans all rows and invokes assign for every column value.
(rows *sql.Rows, assign AssignFunc)
| 34 | |
| 35 | // readRows scans all rows and invokes assign for every column value. |
| 36 | func readRows(rows *sql.Rows, assign AssignFunc) error { |
| 37 | if assign == nil { |
| 38 | return nil |
| 39 | } |
| 40 | |
| 41 | columns, err := rows.Columns() |
| 42 | if err != nil { |
| 43 | return err |
| 44 | } |
| 45 | |
| 46 | values := makeValues(len(columns)) |
| 47 | for rows.Next() { |
| 48 | if err := rows.Scan(values...); err != nil { |
| 49 | return err |
| 50 | } |
| 51 | for i := range values { |
| 52 | assign(columns[i], valueToString(values[i]), i == len(values)-1) |
| 53 | } |
| 54 | } |
| 55 | return rows.Err() |
| 56 | } |
| 57 | |
| 58 | func valueToString(value any) string { |
| 59 | v, ok := value.(*sql.NullString) |
no test coverage detected
searching dependent graphs…