| 536 | } |
| 537 | |
| 538 | func (mgb *MetadataGroupBy) sqlScan(ctx context.Context, root *MetadataQuery, v any) error { |
| 539 | selector := root.sqlQuery(ctx).Select() |
| 540 | aggregation := make([]string, 0, len(mgb.fns)) |
| 541 | for _, fn := range mgb.fns { |
| 542 | aggregation = append(aggregation, fn(selector)) |
| 543 | } |
| 544 | if len(selector.SelectedColumns()) == 0 { |
| 545 | columns := make([]string, 0, len(*mgb.flds)+len(mgb.fns)) |
| 546 | for _, f := range *mgb.flds { |
| 547 | columns = append(columns, selector.C(f)) |
| 548 | } |
| 549 | columns = append(columns, aggregation...) |
| 550 | selector.Select(columns...) |
| 551 | } |
| 552 | selector.GroupBy(selector.Columns(*mgb.flds...)...) |
| 553 | if err := selector.Err(); err != nil { |
| 554 | return err |
| 555 | } |
| 556 | rows := &sql.Rows{} |
| 557 | query, args := selector.Query() |
| 558 | if err := mgb.build.driver.Query(ctx, query, args, rows); err != nil { |
| 559 | return err |
| 560 | } |
| 561 | defer rows.Close() |
| 562 | return sql.ScanSlice(rows, v) |
| 563 | } |
| 564 | |
| 565 | // MetadataSelect is the builder for selecting fields of Metadata entities. |
| 566 | type MetadataSelect struct { |