Implement ynab-export
This commit is contained in:
@ -53,6 +53,49 @@ func (q *Queries) DeleteAllAssignments(ctx context.Context, budgetID uuid.UUID)
|
||||
return result.RowsAffected()
|
||||
}
|
||||
|
||||
const getAllAssignments = `-- name: GetAllAssignments :many
|
||||
SELECT assignments.date, categories.name as category, category_groups.name as group, assignments.amount
|
||||
FROM assignments
|
||||
INNER JOIN categories ON categories.id = assignments.category_id
|
||||
INNER JOIN category_groups ON categories.category_group_id = category_groups.id
|
||||
WHERE category_groups.budget_id = $1
|
||||
`
|
||||
|
||||
type GetAllAssignmentsRow struct {
|
||||
Date time.Time
|
||||
Category string
|
||||
Group string
|
||||
Amount Numeric
|
||||
}
|
||||
|
||||
func (q *Queries) GetAllAssignments(ctx context.Context, budgetID uuid.UUID) ([]GetAllAssignmentsRow, error) {
|
||||
rows, err := q.db.QueryContext(ctx, getAllAssignments, budgetID)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
defer rows.Close()
|
||||
var items []GetAllAssignmentsRow
|
||||
for rows.Next() {
|
||||
var i GetAllAssignmentsRow
|
||||
if err := rows.Scan(
|
||||
&i.Date,
|
||||
&i.Category,
|
||||
&i.Group,
|
||||
&i.Amount,
|
||||
); err != nil {
|
||||
return nil, err
|
||||
}
|
||||
items = append(items, i)
|
||||
}
|
||||
if err := rows.Close(); err != nil {
|
||||
return nil, err
|
||||
}
|
||||
if err := rows.Err(); err != nil {
|
||||
return nil, err
|
||||
}
|
||||
return items, nil
|
||||
}
|
||||
|
||||
const getAssignmentsByMonthAndCategory = `-- name: GetAssignmentsByMonthAndCategory :many
|
||||
SELECT date, category_id, budget_id, amount
|
||||
FROM assignments_by_month
|
||||
|
Reference in New Issue
Block a user