-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathdbms.py
61 lines (52 loc) · 1.96 KB
/
dbms.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
import sqlparse
from dbms_query import *
class Dbms:
def __init__(self):
self.__query = []
self.__input = ''
pass
def __error_message__(self, code):
error_msg_dict = {
0: "Thanks for using skbly7's DBMS. Bye.",
404: "ERROR 404: You have used such a type in your SQL syntax "
"which is currently not supported by this DBMS; ",
1064: "ERROR 1064 (42000): You have an error in your SQL syntax; "
"check the manual for the right syntax to use."
}
print error_msg_dict[code]
return
def __break_n_execute_query__(self):
for query in self.__query:
self.__execute__(query)
def __type_verify_wrapper__(self, parsed_query):
type = parsed_query.get_type()
verified = True
if type == u'UNKNOWN':
if str.upper(str(parsed_query.tokens[0])) == u'EXIT':
self.__error_message__(0)
exit(0)
else:
self.__error_message__(1064)
verified = False
return verified
def __type_supported__(self, query_type):
supported = True
supported_types = ['SELECT']
if query_type not in supported_types:
supported = False
self.__error_message__(404)
return supported
def __execute__(self, query):
parsed_query = sqlparse.parse(query)[0]
query_type = parsed_query.get_type()
type_verified = self.__type_verify_wrapper__(parsed_query)
if type_verified:
type_supported = self.__type_supported__(query_type)
if type_supported:
type = globals()[query_type.title()]
type_instance = type()
type_instance.execute(query, parsed_query)
def execute(self, input):
self.__input = input
self.__query = sqlparse.split(self.__input)
self.__break_n_execute_query__()