-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathNoteDB.py
76 lines (67 loc) · 2.3 KB
/
NoteDB.py
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
import pymysql as mysql
from Note import Note
class NoteDB:
def __init__(self,username="",password=""):
try:
NoteDB.db=mysql.connect("localhost",username,password,"noteapp")
NoteDB.cursor=NoteDB.db.cursor()
except Exception as e:
raise
def add_note(self,note):
q="insert into note(msg) values('%s')"%(note.get_msg())
try:
NoteDB.cursor.execute(q)
NoteDB.db.commit()
except Exception as e:
print(e)
NoteDB.db.rollback()
raise
def get_one_note(self,idt):
q="select * from note where id=%d"%(idt)
try:
NoteDB.cursor.execute(q)
result=NoteDB.cursor.fetchall()
obj=Note(idt=result[0],msg=result[1],time=result[2])
return obj
except Exception as e:
raise
def get_all_notes(self):
q="select * from note order by time desc;"
try:
NoteDB.cursor.execute(q)
notes=[]
results=NoteDB.cursor.fetchall()
for result in results:
obj=Note(idt=result[0],msg=result[1],time=result[2])
notes.append(obj)
return notes
except Exception as e:
raise
def update_note(self,note):
q="update note set msg='%s' where id=%d"%(note.get_msg(),note.get_idt())
try:
NoteDB.cursor.execute(q)
NoteDB.db.commit()
except Exception as e:
NoteDB.db.rollback()
raise
def search_notes(self,query):
q="select * from note where msg like '%{0}%' order by time desc".format(query)
try:
NoteDB.cursor.execute(q)
notes=[]
results=NoteDB.cursor.fetchall()
for result in results:
obj=Note(idt=result[0],msg=result[1],time=result[2])
notes.append(obj)
return notes
except Exception as e:
raise
def delete_note(self,note):
q="delete from note where id=%d"%(note.get_idt())
try:
NoteDB.cursor.execute(q)
NoteDB.db.commit()
except Exception as e:
NoteDB.db.rollback()
raise