-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathdatabase.py
More file actions
42 lines (38 loc) · 1.36 KB
/
database.py
File metadata and controls
42 lines (38 loc) · 1.36 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
import mysql.connector
def get_connection():
"""Créer une connexion à la base de données MySQL."""
return mysql.connector.connect(
host="***", # Adresse du serveur MySQL
user="***", # Utilisateur MySQL
password="***", # Mot de passe utilisateur
database="***", # Nom de la base de données
port=3306 # Port exposé par MySQL
)
def add_devoir(nom, deadline, pdf=None, description=None, rappel_at=None):
"""Ajoute un devoir dans la base de données."""
conn = get_connection()
cursor = conn.cursor()
query = """
INSERT INTO devoirs (nom, deadline, pdf, description, rappel_at)
VALUES (%s, %s, %s, %s, %s)
"""
cursor.execute(query, (nom, deadline, pdf, description, rappel_at))
conn.commit()
conn.close()
def fetch_devoirs():
"""Récupère tous les devoirs depuis la base de données."""
conn = get_connection()
cursor = conn.cursor(dictionary=True)
query = "SELECT * FROM devoirs ORDER BY deadline"
cursor.execute(query)
devoirs = cursor.fetchall()
conn.close()
return devoirs
def delete_devoir(devoir_id):
"""Supprime un devoir par son ID."""
conn = get_connection()
cursor = conn.cursor()
query = "DELETE FROM devoirs WHERE id = %s"
cursor.execute(query, (devoir_id,))
conn.commit()
conn.close()