|
17 | 17 | -----------------------------------------------------------------
|
18 | 18 | """
|
19 | 19 |
|
20 |
| -from typing import Union |
21 |
| - |
22 | 20 | from app.translator.const import DEFAULT_VALUE_TYPE
|
| 21 | +from app.translator.core.custom_types.values import ValueType |
23 | 22 | from app.translator.core.mapping import LogSourceSignature
|
24 | 23 | from app.translator.core.render import BaseFieldValueRender, PlatformQueryRender
|
| 24 | +from app.translator.platforms.base.sql.str_value_manager import sql_str_value_manager |
25 | 25 |
|
26 | 26 |
|
27 | 27 | class SqlFieldValueRender(BaseFieldValueRender):
|
| 28 | + str_value_manager = sql_str_value_manager |
| 29 | + |
| 30 | + @staticmethod |
| 31 | + def _wrap_str_value(value: str) -> str: |
| 32 | + return f"'{value}'" |
| 33 | + |
28 | 34 | def equal_modifier(self, field: str, value: DEFAULT_VALUE_TYPE) -> str:
|
29 | 35 | if isinstance(value, list):
|
30 | 36 | return f"({self.or_token.join([self.equal_modifier(field=field, value=v) for v in value])})"
|
31 |
| - return f"{field} = '{value}'" |
| 37 | + return f"{field} = {self._pre_process_value(field, value, wrap_str=True)}" |
32 | 38 |
|
33 |
| - def less_modifier(self, field: str, value: Union[int, str]) -> str: |
34 |
| - return f"{field} < '{value}'" |
| 39 | + def not_equal_modifier(self, field: str, value: DEFAULT_VALUE_TYPE) -> str: |
| 40 | + if isinstance(value, list): |
| 41 | + return f"({self.or_token.join([self.not_equal_modifier(field=field, value=v) for v in value])})" |
| 42 | + return f"{field} != {self._pre_process_value(field, value, wrap_str=True)}" |
35 | 43 |
|
36 |
| - def less_or_equal_modifier(self, field: str, value: Union[int, str]) -> str: |
37 |
| - return f"{field} <= '{value}'" |
| 44 | + def less_modifier(self, field: str, value: DEFAULT_VALUE_TYPE) -> str: |
| 45 | + return f"{field} < {self._pre_process_value(field, value, wrap_str=True)}" |
38 | 46 |
|
39 |
| - def greater_modifier(self, field: str, value: Union[int, str]) -> str: |
40 |
| - return f"{field} > '{value}'" |
| 47 | + def less_or_equal_modifier(self, field: str, value: DEFAULT_VALUE_TYPE) -> str: |
| 48 | + return f"{field} <= {self._pre_process_value(field, value, wrap_str=True)}" |
41 | 49 |
|
42 |
| - def greater_or_equal_modifier(self, field: str, value: Union[int, str]) -> str: |
43 |
| - return f"{field} >= '{value}'" |
| 50 | + def greater_modifier(self, field: str, value: DEFAULT_VALUE_TYPE) -> str: |
| 51 | + return f"{field} > {self._pre_process_value(field, value, wrap_str=True)}" |
44 | 52 |
|
45 |
| - def not_equal_modifier(self, field: str, value: DEFAULT_VALUE_TYPE) -> str: |
46 |
| - if isinstance(value, list): |
47 |
| - return f"({self.or_token.join([self.not_equal_modifier(field=field, value=v) for v in value])})" |
48 |
| - return f"{field} != '{value}'" |
| 53 | + def greater_or_equal_modifier(self, field: str, value: DEFAULT_VALUE_TYPE) -> str: |
| 54 | + return f"{field} >= {self._pre_process_value(field, value, wrap_str=True)}" |
49 | 55 |
|
50 | 56 | def contains_modifier(self, field: str, value: DEFAULT_VALUE_TYPE) -> str:
|
51 | 57 | if isinstance(value, list):
|
52 | 58 | return f"({self.or_token.join(self.contains_modifier(field=field, value=v) for v in value)})"
|
53 |
| - return f"{field} ILIKE '%{value}%' ESCAPE '\\'" |
| 59 | + return f"{field} like '%{self._pre_process_value(field, value)}%'" |
54 | 60 |
|
55 | 61 | def endswith_modifier(self, field: str, value: DEFAULT_VALUE_TYPE) -> str:
|
56 | 62 | if isinstance(value, list):
|
57 | 63 | return f"({self.or_token.join(self.endswith_modifier(field=field, value=v) for v in value)})"
|
58 |
| - return f"{field} ILIKE '%{value}' ESCAPE '\\'" |
| 64 | + return f"{field} like '%{self._pre_process_value(field, value)}'" |
59 | 65 |
|
60 | 66 | def startswith_modifier(self, field: str, value: DEFAULT_VALUE_TYPE) -> str:
|
61 | 67 | if isinstance(value, list):
|
62 | 68 | return f"({self.or_token.join(self.startswith_modifier(field=field, value=v) for v in value)})"
|
63 |
| - return f"{field} ILIKE '{value}%' ESCAPE '\\'" |
| 69 | + return f"{field} like '{self._pre_process_value(field, value)}%'" |
64 | 70 |
|
65 | 71 | def regex_modifier(self, field: str, value: DEFAULT_VALUE_TYPE) -> str:
|
66 | 72 | if isinstance(value, list):
|
67 | 73 | return f"({self.or_token.join(self.regex_modifier(field=field, value=v) for v in value)})"
|
68 |
| - return f"{field} ILIKE '{value}' ESCAPE '\\'" |
| 74 | + regex_str = self._pre_process_value(field, value, value_type=ValueType.regex_value, wrap_str=True) |
| 75 | + return f"regexp_like({field}, {regex_str})" |
69 | 76 |
|
70 | 77 |
|
71 | 78 | class SqlQueryRender(PlatformQueryRender):
|
|
0 commit comments