index — crispy-website @ 9a977c7c0d1f1c7ecd1c18b2172ca8172a49b024

My personal homepage (very crispy)

internal/repo/sql.go (view raw)

 1
 2
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
package repo

import (
	"crispy-website/internal/db"
	"database/sql"
	"log"

	_ "github.com/mattn/go-sqlite3"
)

type Repository struct {
	DB *sql.DB
}

func NewRepository(dbName string) (*Repository, error) {
	db, err := sql.Open("sqlite3", dbName)
	if err != nil {
		panic("couldn't open db")
	}

	return &Repository{DB: db}, nil
}

func (r *Repository) Close() error {
	return r.DB.Close()
}

func (r *Repository) LoadMusic() []db.MusicItem {
	rows, err := r.DB.Query("SELECT * FROM music ORDER BY purchase_date DESC")
	if err != nil {
		panic(err)
	}
	defer rows.Close()

	var results []db.MusicItem
	for rows.Next() {
		var result db.MusicItem
		err := rows.Scan(
			&result.Id,
			&result.External_ids,
			&result.Name,
			&result.Artist,
			&result.Price,
			&result.Seller,
			&result.Note,
			&result.Purchase_date)
		if err != nil {
			log.Print(err)
		}
		results = append(results, result)
	}
	return results
}

func (r *Repository) GetSpending() (value float32) {
	err := r.DB.QueryRow("SELECT ROUND(SUM(price), 2) FROM music").Scan(&value)

	if err == sql.ErrNoRows {
		log.Println("No rows found")
	} else if err != nil {
		log.Fatal(err)
	}

	return value
}