-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathdatabase.py
More file actions
81 lines (69 loc) · 2.52 KB
/
database.py
File metadata and controls
81 lines (69 loc) · 2.52 KB
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
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
# db.py
import psycopg2
import os
def get_db_connection():
return psycopg2.connect(os.environ.get('DATABASE_URL'))
def load_expenses(month):
conn = get_db_connection()
cursor = conn.cursor() # Use RealDictCursor here
cursor.execute("SELECT * FROM expenselog WHERE EXTRACT(MONTH FROM dateofExpense) = %s ORDER BY dateofExpense DESC", (month,))
expenses = cursor.fetchall()
conn.close()
print(f"Fetched expenses: {expenses}") # Debugging line
return expenses
def load_sum(month):
conn = get_db_connection()
cur = conn.cursor()
if month == 0:
cur.execute("SELECT SUM(amount) FROM expenselog;")
else:
cur.execute("SELECT SUM(amount) FROM expenselog WHERE EXTRACT(MONTH FROM dateofExpense) = %s;", (month,))
total = cur.fetchone()
conn.close()
print(total[0])
return total[0] # return the numeric value
def load_expense(expense_id):
conn = get_db_connection()
cur = conn.cursor()
cur.execute("SELECT * FROM expenselog WHERE id = %s;", (expense_id,))
expense = cur.fetchone()
conn.close()
if expense is None:
return None # or handle this case as needed
# Return the full tuple or create a dictionary to make accessing easier
return {
'id': expense[0],
'amount': expense[1],
'comments': expense[2],
'dateofExpense': expense[3],
'dateofLog': expense[4],
'mode': expense[5],
'category':expense[6]
}
def add_expense(data, curr):
conn = get_db_connection()
cursor = conn.cursor()
cursor.execute("INSERT INTO expenselog (amount, comments, dateofExpense, dateofLog, mode, category) VALUES (%s, %s, %s, %s, %s, %s)",
(data['amount'], data['desc'], data['date'], curr, data['mode'],data['category']))
conn.commit() # Make sure this commit is executed
conn.close()
def delete_expense(expense_id):
conn = get_db_connection()
cur = conn.cursor()
cur.execute("DELETE FROM expenselog WHERE id = %s;", (expense_id,))
conn.commit()
conn.close()
def load_all():
conn = get_db_connection()
cur = conn.cursor()
cur.execute("SELECT * FROM expenselog ORDER BY dateofExpense DESC;")
expense = cur.fetchall()
conn.close()
return expense
def fetch_analysis(month):
conn = get_db_connection()
cur = conn.cursor()
cur.execute("SELECT category,sum(amount) from expenselog WHERE EXTRACT(MONTH FROM dateofExpense) = %s group by category;", (month,))
analysis = cur.fetchall()
conn.close()
return analysis