mirror of
https://github.com/Syngnat/GoNavi.git
synced 2026-05-12 04:19:40 +08:00
- DataViewer 主键列元数据异步拉取,首屏数据优先渲染 - 查询页增加结果集最大行数限制,减少大表全量返回 - DBQuery 引入 Context 超时,降低长查询对 UI 的阻塞风险 - 查询行数设置持久化保存 Closes #48 Closes #49
37 lines
770 B
Go
37 lines
770 B
Go
package db
|
|
|
|
import "database/sql"
|
|
|
|
func scanRows(rows *sql.Rows) ([]map[string]interface{}, []string, error) {
|
|
columns, err := rows.Columns()
|
|
if err != nil {
|
|
return nil, nil, err
|
|
}
|
|
|
|
resultData := make([]map[string]interface{}, 0)
|
|
|
|
for rows.Next() {
|
|
values := make([]interface{}, len(columns))
|
|
valuePtrs := make([]interface{}, len(columns))
|
|
for i := range columns {
|
|
valuePtrs[i] = &values[i]
|
|
}
|
|
|
|
if err := rows.Scan(valuePtrs...); err != nil {
|
|
continue
|
|
}
|
|
|
|
entry := make(map[string]interface{}, len(columns))
|
|
for i, col := range columns {
|
|
entry[col] = normalizeQueryValue(values[i])
|
|
}
|
|
resultData = append(resultData, entry)
|
|
}
|
|
|
|
if err := rows.Err(); err != nil {
|
|
return resultData, columns, err
|
|
}
|
|
return resultData, columns, nil
|
|
}
|
|
|