Python sqlparse.sql.Identifier() Examples
The following are 30
code examples of sqlparse.sql.Identifier().
You can vote up the ones you like or vote down the ones you don't like,
and go to the original project or source file by following the links above each example.
You may also want to check out all available functions/classes of the module
sqlparse.sql
, or try the search function
.
Example #1
Source File: utils.py From pgcli with BSD 3-Clause "New" or "Revised" License | 8 votes |
def parse_partial_identifier(word): """Attempt to parse a (partially typed) word as an identifier word may include a schema qualification, like `schema_name.partial_name` or `schema_name.` There may also be unclosed quotation marks, like `"schema`, or `schema."partial_name` :param word: string representing a (partially complete) identifier :return: sqlparse.sql.Identifier, or None """ p = sqlparse.parse(word)[0] n_tok = len(p.tokens) if n_tok == 1 and isinstance(p.tokens[0], Identifier): return p.tokens[0] elif p.token_next_by(m=(Error, '"'))[1]: # An unmatched double quote, e.g. '"foo', 'foo."', or 'foo."bar' # Close the double quote, then reparse return parse_partial_identifier(word + '"') else: return None
Example #2
Source File: grouping.py From SublimeText-SQLTools with GNU General Public License v3.0 | 7 votes |
def group_identifier_list(tlist): m_role = T.Keyword, ('null', 'role') sqlcls = (sql.Function, sql.Case, sql.Identifier, sql.Comparison, sql.IdentifierList, sql.Operation) ttypes = (T_NUMERICAL + T_STRING + T_NAME + (T.Keyword, T.Comment, T.Wildcard)) def match(token): return token.match(T.Punctuation, ',') def valid(token): return imt(token, i=sqlcls, m=m_role, t=ttypes) def post(tlist, pidx, tidx, nidx): return pidx, nidx valid_prev = valid_next = valid _group(tlist, sql.IdentifierList, match, valid_prev, valid_next, post, extend=True)
Example #3
Source File: grouping.py From SublimeText-SQLTools with GNU General Public License v3.0 | 6 votes |
def group_arrays(tlist): sqlcls = sql.SquareBrackets, sql.Identifier, sql.Function ttypes = T.Name, T.String.Symbol def match(token): return isinstance(token, sql.SquareBrackets) def valid_prev(token): return imt(token, i=sqlcls, t=ttypes) def valid_next(token): return True def post(tlist, pidx, tidx, nidx): return pidx, tidx _group(tlist, sql.Identifier, match, valid_prev, valid_next, post, extend=True, recurse=False)
Example #4
Source File: grouping.py From uroboroSQL-formatter with BSD 3-Clause "New" or "Revised" License | 6 votes |
def group_aliased(tlist): clss = (sql.Identifier, sql.Function, sql.Case) [group_aliased(sgroup) for sgroup in tlist.get_sublists() if not isinstance(sgroup, clss)] idx = 0 token = tlist.token_next_by_instance(idx, clss) while token: next_ = tlist.token_next(tlist.token_index(token)) if next_ is not None and isinstance(next_, clss): # for jython str.upper() # if not next_.value.upper().startswith('VARCHAR'): text = next_.value if sys.version_info[0] < 3 and isinstance(text, str): text = text.decode('utf-8').upper().encode('utf-8') if not text.startswith('VARCHAR'): grp = tlist.tokens_between(token, next_)[1:] token.tokens.extend(grp) for t in grp: tlist.tokens.remove(t) idx = tlist.token_index(token) + 1 token = tlist.token_next_by_instance(idx, clss)
Example #5
Source File: grouping.py From codenn with MIT License | 6 votes |
def group_aliased(tlist): clss = (sql.Identifier, sql.Function, sql.Case) [group_aliased(sgroup) for sgroup in tlist.get_sublists() if not isinstance(sgroup, clss)] idx = 0 token = tlist.token_next_by_instance(idx, clss) while token: next_ = tlist.token_next(tlist.token_index(token)) if next_ is not None and isinstance(next_, clss): if not next_.value.upper().startswith('VARCHAR'): grp = tlist.tokens_between(token, next_)[1:] token.tokens.extend(grp) for t in grp: tlist.tokens.remove(t) idx = tlist.token_index(token) + 1 token = tlist.token_next_by_instance(idx, clss)
Example #6
Source File: filters.py From uroboroSQL-formatter with BSD 3-Clause "New" or "Revised" License | 6 votes |
def __custom_process_parenthesis_order(self, parenthesis): open_punc = parenthesis.token_next_match(0, T.Punctuation, '(') close_punc = parenthesis.token_next_match(open_punc, T.Punctuation, ')') self.indent += 2 parenthesis.insert_after(open_punc, self.nl()) for token in parenthesis.tokens_between(open_punc, close_punc)[1:-1]: if isinstance(token, Phrase): parenthesis.insert_before(token, self.nl()) self._process_phrase(token, kwds=False) parenthesis.insert_after(token, self.nl_with_indent(1)) elif isinstance(token, sql.Identifier) and len(token.tokens)==1 and isinstance(token.tokens[0], Phrase): # 中がPhraseのIdentifier child_token = token.tokens[0] parenthesis.insert_before(token, self.nl()) self._process_phrase(child_token, kwds=False) parenthesis.insert_after(token, self.nl_with_indent(1)) elif token.is_group(): self._process(token) self.indent -= 1 parenthesis.insert_before(close_punc, self.nl()) self.indent -= 1
Example #7
Source File: grouping.py From uroboroSQL-formatter with BSD 3-Clause "New" or "Revised" License | 6 votes |
def init_group_token(self, token): tokens = token.get_target_tokens() with_token = tokens[0] start_prev = with_token end = None for tkn in tokens[1:]: if tu.is_comma(tkn): start = tu.token_next_enable(token, start_prev) token.group_tokens(sql.Identifier, token.tokens_between(start, end)) start_prev = tkn continue end = tkn start = tu.token_next_enable(token, with_token) end = tu.token_prev_enable(token) token.group_tokens(sql.IdentifierList, token.tokens_between(start, end))
Example #8
Source File: sql_handler.py From mysql_streamer with Apache License 2.0 | 6 votes |
def pop(self): next_val = self.peek() self.index += 1 # We need to handle three cases here where the next_val could be: # 1. <table_name> ('business') # 2. <database_name>.<table_name> ('yelp.business') # 3. <database_name>.<table_name> <extended_query> # ('yelp.business change col_one col_two') # In all the cases we should return a token consisting of only the table # name or if the database name is present then the database name and the # table name. Case #3 occurs because SQLParse incorrectly parses certain # queries. if isinstance(next_val, Identifier): tokens = next_val.tokens if len(tokens) > 1 and tokens[1].value == '.': str_token = "{db_name}{punctuation}{table_name}".format( db_name=tokens[0].value, punctuation=tokens[1].value, table_name=tokens[2].value ) return TK(Token.Name, str_token) else: return next_val.token_first() return next_val
Example #9
Source File: grouping.py From SublimeText-SQLTools with GNU General Public License v3.0 | 6 votes |
def group_operator(tlist): ttypes = T_NUMERICAL + T_STRING + T_NAME sqlcls = (sql.SquareBrackets, sql.Parenthesis, sql.Function, sql.Identifier, sql.Operation) def match(token): return imt(token, t=(T.Operator, T.Wildcard)) def valid(token): return imt(token, i=sqlcls, t=ttypes) def post(tlist, pidx, tidx, nidx): tlist[tidx].ttype = T.Operator return pidx, nidx valid_prev = valid_next = valid _group(tlist, sql.Operation, match, valid_prev, valid_next, post, extend=False)
Example #10
Source File: grouping.py From SublimeText-SQLTools with GNU General Public License v3.0 | 6 votes |
def group_comparison(tlist): sqlcls = (sql.Parenthesis, sql.Function, sql.Identifier, sql.Operation) ttypes = T_NUMERICAL + T_STRING + T_NAME def match(token): return token.ttype == T.Operator.Comparison def valid(token): if imt(token, t=ttypes, i=sqlcls): return True elif token and token.is_keyword and token.normalized == 'NULL': return True else: return False def post(tlist, pidx, tidx, nidx): return pidx, nidx valid_prev = valid_next = valid _group(tlist, sql.Comparison, match, valid_prev, valid_next, post, extend=False)
Example #11
Source File: search_utils.py From mlflow with Apache License 2.0 | 6 votes |
def _validate_order_by_and_generate_token(cls, order_by): try: parsed = sqlparse.parse(order_by) except Exception: raise MlflowException(f"Error on parsing order_by clause '{order_by}'", error_code=INVALID_PARAMETER_VALUE) if len(parsed) != 1 or not isinstance(parsed[0], Statement): raise MlflowException(f"Invalid order_by clause '{order_by}'. Could not be parsed.", error_code=INVALID_PARAMETER_VALUE) statement = parsed[0] if len(statement.tokens) == 1 and isinstance(statement[0], Identifier): token_value = statement.tokens[0].value elif len(statement.tokens) == 1 and \ statement.tokens[0].match(ttype=TokenType.Keyword, values=[cls.ORDER_BY_KEY_TIMESTAMP]): token_value = cls.ORDER_BY_KEY_TIMESTAMP elif statement.tokens[0].match(ttype=TokenType.Keyword, values=[cls.ORDER_BY_KEY_TIMESTAMP])\ and all([token.is_whitespace for token in statement.tokens[1:-1]])\ and statement.tokens[-1].ttype == TokenType.Keyword.Order: token_value = cls.ORDER_BY_KEY_TIMESTAMP + ' ' + statement.tokens[-1].value else: raise MlflowException(f"Invalid order_by clause '{order_by}'. Could not be parsed.", error_code=INVALID_PARAMETER_VALUE) return token_value
Example #12
Source File: grouping.py From SublimeText-SQLTools with GNU General Public License v3.0 | 6 votes |
def group_period(tlist): def match(token): return token.match(T.Punctuation, '.') def valid_prev(token): sqlcls = sql.SquareBrackets, sql.Identifier ttypes = T.Name, T.String.Symbol return imt(token, i=sqlcls, t=ttypes) def valid_next(token): # issue261, allow invalid next token return True def post(tlist, pidx, tidx, nidx): # next_ validation is being performed here. issue261 sqlcls = sql.SquareBrackets, sql.Function ttypes = T.Name, T.String.Symbol, T.Wildcard next_ = tlist[nidx] if nidx is not None else None valid_next = imt(next_, i=sqlcls, t=ttypes) return (pidx, nidx) if valid_next else (pidx, tidx) _group(tlist, sql.Identifier, match, valid_prev, valid_next, post)
Example #13
Source File: utils.py From mssql-cli with BSD 3-Clause "New" or "Revised" License | 6 votes |
def parse_partial_identifier(word): """Attempt to parse a (partially typed) word as an identifier word may include a schema qualification, like `schema_name.partial_name` or `schema_name.` There may also be unclosed quotation marks, like `"schema`, or `schema."partial_name` :param word: string representing a (partially complete) identifier :return: sqlparse.sql.Identifier, or None """ p = sqlparse.parse(word)[0] n_tok = len(p.tokens) if n_tok == 1 and isinstance(p.tokens[0], Identifier): return p.tokens[0] if p.token_next_by(m=(Error, '"'))[1]: # An unmatched double quote, e.g. '"foo', 'foo."', or 'foo."bar' # Close the double quote, then reparse return parse_partial_identifier(word + '"') return None
Example #14
Source File: ParseUtils.py From SublimeText-SQLTools with GNU General Public License v3.0 | 6 votes |
def _extract_table_identifiers(token_stream): for item in token_stream: if isinstance(item, IdentifierList): for ident in item.get_identifiers(): try: alias = ident.get_alias() schema_name = ident.get_parent_name() real_name = ident.get_real_name() except AttributeError: continue if real_name: yield Reference(schema_name, real_name, alias, _identifier_is_function(ident)) elif isinstance(item, Identifier): yield Reference(item.get_parent_name(), item.get_real_name(), item.get_alias(), _identifier_is_function(item)) elif isinstance(item, Function): yield Reference(item.get_parent_name(), item.get_real_name(), item.get_alias(), _identifier_is_function(item))
Example #15
Source File: convert.py From sqlitis with MIT License | 6 votes |
def sql_literal_to_model(tok, m=M): """ :param m: the source model to "append" the literal to. defaults to M - the sqlitis models module (which means a fresh model is created) :return: the resulting model """ def is_string_literal(tok): text = tok.normalized return all([text.startswith('"'), text.endswith('"')]) # sqlparse treats string literals as identifiers if type(tok) is S.Identifier and is_string_literal(tok): return m.Field(tok.normalized, literal=True) elif type(tok) is S.Identifier: return m.Field(tok.normalized) elif tok.ttype is T.Comparison: return m.Op(tok.normalized) elif tok.ttype in [T.Literal, T.String, T.Number, T.Number.Integer, T.Number.Float]: return m.Field(tok.normalized, literal=True) return None
Example #16
Source File: search_utils.py From mlflow with Apache License 2.0 | 5 votes |
def _get_value(cls, identifier_type, token): if identifier_type == cls._METRIC_IDENTIFIER: if token.ttype not in cls.NUMERIC_VALUE_TYPES: raise MlflowException("Expected numeric value type for metric. " "Found {}".format(token.value), error_code=INVALID_PARAMETER_VALUE) return token.value elif identifier_type == cls._PARAM_IDENTIFIER or identifier_type == cls._TAG_IDENTIFIER: if token.ttype in cls.STRING_VALUE_TYPES or isinstance(token, Identifier): return cls._strip_quotes(token.value, expect_quoted_value=True) raise MlflowException("Expected a quoted string value for " "{identifier_type} (e.g. 'my-value'). Got value " "{value}".format(identifier_type=identifier_type, value=token.value), error_code=INVALID_PARAMETER_VALUE) elif identifier_type == cls._ATTRIBUTE_IDENTIFIER: if token.ttype in cls.STRING_VALUE_TYPES or isinstance(token, Identifier): return cls._strip_quotes(token.value, expect_quoted_value=True) else: raise MlflowException("Expected a quoted string value for attributes. " "Got value {value}".format(value=token.value), error_code=INVALID_PARAMETER_VALUE) else: # Expected to be either "param" or "metric". raise MlflowException("Invalid identifier type. Expected one of " "{}.".format([cls._METRIC_IDENTIFIER, cls._PARAM_IDENTIFIER]))
Example #17
Source File: parseutils.py From athenacli with BSD 3-Clause "New" or "Revised" License | 5 votes |
def extract_table_identifiers(token_stream): """yields tuples of (schema_name, table_name, table_alias)""" for item in token_stream: if isinstance(item, IdentifierList): for identifier in item.get_identifiers(): # Sometimes Keywords (such as FROM ) are classified as # identifiers which don't have the get_real_name() method. try: schema_name = identifier.get_parent_name() real_name = identifier.get_real_name() except AttributeError: continue if real_name: yield (schema_name, real_name, identifier.get_alias()) elif isinstance(item, Identifier): real_name = item.get_real_name() schema_name = item.get_parent_name() if real_name: yield (schema_name, real_name, item.get_alias()) else: name = item.get_name() yield (None, name, item.get_alias() or name) elif isinstance(item, Function): yield (None, item.get_name(), item.get_name()) # extract_tables is inspired from examples in the sqlparse lib.
Example #18
Source File: test_grouping.py From codenn with MIT License | 5 votes |
def test_identifier_with_string_literals(): p = sqlparse.parse('foo + \'bar\'')[0] assert len(p.tokens) == 1 assert isinstance(p.tokens[0], sql.Identifier) # This test seems to be wrong. It was introduced when fixing #53, but #111 # showed that this shouldn't be an identifier at all. I'm leaving this # commented in the source for a while. # def test_identifier_string_concat(): # p = sqlparse.parse('\'foo\' || bar')[0] # assert len(p.tokens) == 1 # assert isinstance(p.tokens[0], sql.Identifier)
Example #19
Source File: grouping.py From uroboroSQL-formatter with BSD 3-Clause "New" or "Revised" License | 5 votes |
def group_as(tlist): def _right_valid(token): # Currently limited to DML/DDL. Maybe additional more non SQL reserved # keywords should appear here (see issue8). return not token.ttype in (T.DML, T.DDL) def _left_valid(token): if token.ttype is T.Keyword and token.value in ('NULL',): return True return token.ttype is not T.Keyword _group_left_right(tlist, T.Keyword, 'AS', sql.Identifier, check_right=_right_valid, check_left=_left_valid)
Example #20
Source File: grouping.py From uroboroSQL-formatter with BSD 3-Clause "New" or "Revised" License | 5 votes |
def group_comparison(tlist): def _parts_valid(token): return (token.ttype in (T.String.Symbol, T.String.Single, T.Name, T.Number, T.Number.Float, T.Number.Integer, T.Literal, T.Literal.Number.Integer, T.Name.Placeholder) or isinstance(token, (sql.Identifier, sql.Parenthesis)) or (token.ttype is T.Keyword and token.value.upper() in ['NULL', ])) _group_left_right(tlist, T.Operator.Comparison, None, sql.Comparison, check_left=_parts_valid, check_right=_parts_valid)
Example #21
Source File: test_grouping.py From codenn with MIT License | 5 votes |
def test_identifier_with_op_trailing_ws(): # make sure trailing whitespace isn't grouped with identifier p = sqlparse.parse('foo || bar ')[0] assert len(p.tokens) == 2 assert isinstance(p.tokens[0], sql.Identifier) assert p.tokens[1].ttype is T.Whitespace
Example #22
Source File: test_grouping.py From codenn with MIT License | 5 votes |
def test_identifier_with_operators(): # issue 53 p = sqlparse.parse('foo||bar')[0] assert len(p.tokens) == 1 assert isinstance(p.tokens[0], sql.Identifier) # again with whitespaces p = sqlparse.parse('foo || bar')[0] assert len(p.tokens) == 1 assert isinstance(p.tokens[0], sql.Identifier)
Example #23
Source File: grouping.py From uroboroSQL-formatter with BSD 3-Clause "New" or "Revised" License | 5 votes |
def group_typecasts(tlist): _group_left_right(tlist, T.Punctuation, '::', sql.Identifier)
Example #24
Source File: tokenutils.py From uroboroSQL-formatter with BSD 3-Clause "New" or "Revised" License | 5 votes |
def is_identifier(token): """ Identifier判定 """ return isinstance(token, sql.Identifier)
Example #25
Source File: grouping.py From uroboroSQL-formatter with BSD 3-Clause "New" or "Revised" License | 5 votes |
def __bind_tokens(self, token, tokens): token.usingtoken = None token.usingparenthesistoken = None joins, tokens, _ = self.__get_joins(tokens) identifier, tokens, _ = self.__get_identifier(tokens) token.jointoken = joins[0] token.jointoken.value = self.__build_useingjoin_value(token, token.tokens_between(joins[0], joins[-1])) if not self.using_target: token.identifiertoken = token.group_tokens( sql.Identifier, token.tokens_between(identifier[0], token.tokens[-1]) ) return else: using, tokens, _ = self.__get_using(tokens) using_parenthesis, tokens, _ = self.__get_using_parenthesis(tokens) token.identifiertoken = token.group_tokens( sql.Identifier, token.tokens_between(identifier[0], using[0], exclude_end=True) ) token.usingtoken = using[0] token.usingparenthesistoken = using_parenthesis[0]
Example #26
Source File: test_grouping.py From codenn with MIT License | 5 votes |
def test_identifier_function(self): p = sqlparse.parse('foo() as bar')[0] self.assert_(isinstance(p.tokens[0], sql.Identifier)) self.assert_(isinstance(p.tokens[0].tokens[0], sql.Function)) p = sqlparse.parse('foo()||col2 bar')[0] self.assert_(isinstance(p.tokens[0], sql.Identifier)) self.assert_(isinstance(p.tokens[0].tokens[0], sql.Function))
Example #27
Source File: search_utils.py From mlflow with Apache License 2.0 | 5 votes |
def _validate_comparison(cls, tokens): base_error_string = "Invalid comparison clause" if len(tokens) != 3: raise MlflowException("{}. Expected 3 tokens found {}".format(base_error_string, len(tokens)), error_code=INVALID_PARAMETER_VALUE) if not isinstance(tokens[0], Identifier): raise MlflowException("{}. Expected 'Identifier' found '{}'".format(base_error_string, str(tokens[0])), error_code=INVALID_PARAMETER_VALUE) if not isinstance(tokens[1], Token) and tokens[1].ttype != TokenType.Operator.Comparison: raise MlflowException("{}. Expected comparison found '{}'".format(base_error_string, str(tokens[1])), error_code=INVALID_PARAMETER_VALUE) if not isinstance(tokens[2], Token) and \ (tokens[2].ttype not in cls.STRING_VALUE_TYPES.union(cls.NUMERIC_VALUE_TYPES) or isinstance(tokens[2], Identifier)): raise MlflowException("{}. Expected value token found '{}'".format(base_error_string, str(tokens[2])), error_code=INVALID_PARAMETER_VALUE)
Example #28
Source File: ctes.py From mssql-cli with BSD 3-Clause "New" or "Revised" License | 5 votes |
def _identifiers(tok): if isinstance(tok, IdentifierList): for t in tok.get_identifiers(): # NB: IdentifierList.get_identifiers() can return non-identifiers! if isinstance(t, Identifier): yield t elif isinstance(tok, Identifier): yield tok
Example #29
Source File: sql_parse.py From incubator-superset with Apache License 2.0 | 5 votes |
def _is_identifier(token: Token) -> bool: return isinstance(token, (IdentifierList, Identifier))
Example #30
Source File: operators.py From djongo with GNU Affero General Public License v3.0 | 5 votes |
def __init__(self, *args, **kwargs): super().__init__(*args, **kwargs) self._identifier = SQLToken.token2sql(self.statement.left, self.query) if isinstance(self.statement.right, Identifier): raise SQLDecodeError('Join using WHERE not supported') self._operator = OPERATOR_MAP[self.statement.token_next(0)[1].value] index = re_index(self.statement.right.value) self._constant = self.params[index] if index is not None else None if isinstance(self._constant, dict): self._field_ext, self._constant = next(iter(self._constant.items())) else: self._field_ext = None