-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathquery.py
More file actions
174 lines (150 loc) · 6.92 KB
/
Copy pathquery.py
File metadata and controls
174 lines (150 loc) · 6.92 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
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
from flask import request
import metadata
from metadata import *
class Search:
class Condition:
def __init__(self,request,column,operator,order):
self.request = request
self.column = column
self.operator = operator
self.order = str(order)
def __init__(self, table):
self.conditions = []
self.count = min(10, max(1,request.args.get('cnt', 1, type=int)))
for i in range(self.count):
temp_col = request.args.get('c' + str(i), 'id')
temp_op = request.args.get('op' + str(i), '=')
if not (temp_col in table.__dict__ and temp_op in operators):
self.count -= 1
continue
col = getattr(table, temp_col)
req = request.args.get('s' + str(i), '', type=int if col.type == 'int' else None)
self.conditions.append(self.Condition(req, col, temp_op, i))
def getRequests(self):
return [cond.request for cond in self.conditions]
class QueryBuilder:
countQuery = 'select count(*) from '
def getTableRows(self, table):
return 'select * from ' + table.tableName
def getAnalyticsView(self, table, meta, search):
query = self.createQuery(table, meta)
query = query % self.addColsToSelect_analytics(table, meta)
query += self.joinTable(table, meta)
query += self.addSearchRequest(table, search)
return query
def getTableView(self, table, meta, search, paging, sortCol):
query = self.createQuery(table, meta)
query = query % self.addColsToSelect(table, meta)
query += self.joinTable(table, meta)
query += self.addSearchRequest(table, search)
query += self.addSort(table, meta, sortCol)
query += self.addPage(paging, search.getRequests())
return query
def createQuery(self, table, meta):
query = 'select %s from ' + table.tableName
self.countQuery += table.tableName
return query
def addColsToSelect_analytics(self, table, meta):
return ','.join((field.referenceTable.tableName + '.' + field.referenceCol.colName + ',' + table.tableName + '.' + field.colName)
if isinstance(field, metadata.RefField) else
(table.tableName + '.' + field.colName)
for field in meta)
def addColsToSelect(self, table, meta):
return ','.join(
field.referenceTable.tableName + '.' + field.referenceCol.colName
if isinstance(field, metadata.RefField)
else table.tableName + '.' + field.colName
for field in meta)
def addColsToSelectNoFK(self, table, meta):
return ','.join(table.tableName + '.' + field.colName for field in meta)
def joinTable(self, table, meta):
query = ''
for field in meta:
if isinstance(field, metadata.RefField):
temp = (
' left join ' + field.referenceTable.tableName + ' on ' +
table.tableName + '.' + field.colName + ' = ' +
field.referenceTable.tableName + '.' + field.referenceTable.id.colName + '\n')
query += temp
self.countQuery += temp
return query
def addSearchRequest(self, table, search):
request = []
query = ''
haveConditions = False
for cond in search.conditions:
if cond.request != '':
request.append('%s.%s %s ?')
if isinstance(cond.column, metadata.RefField):
request[-1] = request[-1] % (cond.column.referenceTable.tableName,
cond.column.referenceCol.colName, cond.operator)
elif isinstance(cond.column, metadata.BaseField):
request[-1] = request[-1] % (table.tableName, cond.column.colName, cond.operator)
haveConditions = True
if haveConditions:
temp = ' where ' + ' and '.join(request)
query += temp
self.countQuery += temp
return query
def addSort(self, table, meta, sortCol):
query = ''
col = sortCol
if col in table.__dict__:
col = getattr(table, col)
else:
col = meta[0]
if col in meta:
if isinstance(col, metadata.RefField):
tname = col.referenceTable.tableName
cname = col.referenceCol.colName
ctype = col.referenceCol.type
else:
tname = table.tableName
cname = col.colName
ctype = col.type
query = ' order by %s.%s'
if ctype == "ref_ord":
query += ', %s.%s'
query = query % (tname, "order_number", tname, cname)
else:
query = query % (tname, cname)
return query
def addPage(self, paging, params):
query = ''
paging.nextInit(self.countQuery, params)
query += ' offset %d rows fetch next %d rows only'
query = query % (paging.onPage*paging.page, paging.onPage)
return query
def getRowToModify(self, table, id, meta):
query = self.createQuery(table, meta)
query = query % self.addColsToSelectNoFK(table, meta)
query += (' where %s.id = ' + str(id)) % table.tableName
return query
def getUpdate(self, table, id, meta):
query = 'update %s set\n' % table.tableName
exps = ['%s = ?' % field.colName for field in meta]
query += ','.join(exps)
query += '\nwhere ID = ' + str(id)
return query
def getInsert(self, table, meta, conflict = False):
query = 'insert into %s ' % table if conflict else table.tableName
query += '(%s) ' % ','.join(field if conflict else field.colName for field in meta)
query += 'values (?%s)' % (',?'*(len(meta)-1))
return query
def getConflict(self, table, meta, type_id):
query = 'select c.CONFLICT_GROUP_ID,%s from CONFLICTS c ' % self.addColsToSelect(table,meta)
query += 'inner join SCHED_ITEMS on c.SCHED_ITEM_ID = SCHED_ITEMS.ID '
query += self.joinTable(table, meta)
query += ' where c.CONFLICT_TYPE_ID = %d' % type_id
return query
def getConflictingIDs(self):
query = 'SELECT c.SCHED_ITEM_ID FROM CONFLICTS c'
return query
def createConflict(self, fields):
query = 'select ID,'
query += ','.join('t1.' + field for field in fields)
query += ' from SCHED_ITEMS t1 where exists (select * from SCHED_ITEMS t2 where '
query += ' AND '.join('t1.%s = t2.%s' % (field, field) for field in fields)
query += ' AND t1.ID <> t2.ID)'
query += ' GROUP BY %s,ID' % ','.join(fields)
return query