# Generated from SqlSmall.g4 by ANTLR 4.9.3
# encoding: utf-8
from antlr4 import *
from io import StringIO
import sys
if sys.version_info[1] > 5:
	from typing import TextIO
else:
	from typing.io import TextIO


def serializedATN():
    with StringIO() as buf:
        buf.write("\3\u608b\ua72a\u8133\ub9ed\u417c\u3be7\u7786\u5964\3\u00ac")
        buf.write("\u02e9\4\2\t\2\4\3\t\3\4\4\t\4\4\5\t\5\4\6\t\6\4\7\t\7")
        buf.write("\4\b\t\b\4\t\t\t\4\n\t\n\4\13\t\13\4\f\t\f\4\r\t\r\4\16")
        buf.write("\t\16\4\17\t\17\4\20\t\20\4\21\t\21\4\22\t\22\4\23\t\23")
        buf.write("\4\24\t\24\4\25\t\25\4\26\t\26\4\27\t\27\4\30\t\30\4\31")
        buf.write("\t\31\4\32\t\32\4\33\t\33\4\34\t\34\4\35\t\35\4\36\t\36")
        buf.write("\4\37\t\37\4 \t \4!\t!\4\"\t\"\4#\t#\4$\t$\4%\t%\4&\t")
        buf.write("&\4\'\t\'\4(\t(\4)\t)\4*\t*\4+\t+\4,\t,\4-\t-\4.\t.\4")
        buf.write("/\t/\4\60\t\60\4\61\t\61\4\62\t\62\4\63\t\63\4\64\t\64")
        buf.write("\4\65\t\65\4\66\t\66\4\67\t\67\48\t8\49\t9\4:\t:\4;\t")
        buf.write(";\4<\t<\4=\t=\4>\t>\4?\t?\4@\t@\4A\tA\4B\tB\4C\tC\4D\t")
        buf.write("D\3\2\3\2\3\2\7\2\u008c\n\2\f\2\16\2\u008f\13\2\3\2\5")
        buf.write("\2\u0092\n\2\3\2\3\2\3\3\3\3\3\3\5\3\u0099\n\3\3\3\5\3")
        buf.write("\u009c\n\3\3\3\5\3\u009f\n\3\3\3\5\3\u00a2\n\3\3\3\5\3")
        buf.write("\u00a5\n\3\3\4\3\4\3\4\3\4\5\4\u00ab\n\4\3\4\5\4\u00ae")
        buf.write("\n\4\3\4\5\4\u00b1\n\4\3\4\5\4\u00b4\n\4\3\4\3\4\3\5\3")
        buf.write("\5\3\6\3\6\5\6\u00bc\n\6\3\6\3\6\3\7\3\7\3\7\3\7\7\7\u00c4")
        buf.write("\n\7\f\7\16\7\u00c7\13\7\3\b\3\b\3\b\3\t\3\t\3\t\3\t\3")
        buf.write("\t\7\t\u00d1\n\t\f\t\16\t\u00d4\13\t\3\n\3\n\3\n\3\13")
        buf.write("\3\13\3\13\3\13\3\13\7\13\u00de\n\13\f\13\16\13\u00e1")
        buf.write("\13\13\3\f\3\f\3\f\3\r\3\r\3\r\3\16\3\16\3\16\3\16\5\16")
        buf.write("\u00ed\n\16\3\17\5\17\u00f0\n\17\3\17\3\17\3\17\5\17\u00f5")
        buf.write("\n\17\3\17\5\17\u00f8\n\17\3\17\3\17\3\17\5\17\u00fd\n")
        buf.write("\17\3\17\3\17\5\17\u0101\n\17\3\17\5\17\u0104\n\17\3\17")
        buf.write("\5\17\u0107\n\17\3\20\3\20\3\20\3\20\3\20\3\20\3\20\7")
        buf.write("\20\u0110\n\20\f\20\16\20\u0113\13\20\3\20\3\20\5\20\u0117")
        buf.write("\n\20\3\21\3\21\5\21\u011b\n\21\3\22\3\22\3\22\5\22\u0120")
        buf.write("\n\22\3\23\3\23\7\23\u0124\n\23\f\23\16\23\u0127\13\23")
        buf.write("\3\24\3\24\3\24\5\24\u012c\n\24\3\24\3\24\3\24\5\24\u0131")
        buf.write("\n\24\3\24\3\24\3\24\3\24\3\24\5\24\u0138\n\24\5\24\u013a")
        buf.write("\n\24\3\25\3\25\3\25\6\25\u013f\n\25\r\25\16\25\u0140")
        buf.write("\3\25\3\25\5\25\u0145\n\25\3\25\3\25\3\25\3\25\6\25\u014b")
        buf.write("\n\25\r\25\16\25\u014c\3\25\3\25\5\25\u0151\n\25\3\25")
        buf.write("\3\25\5\25\u0155\n\25\3\26\3\26\3\26\5\26\u015a\n\26\3")
        buf.write("\27\3\27\3\27\7\27\u015f\n\27\f\27\16\27\u0162\13\27\3")
        buf.write("\30\3\30\3\30\3\30\3\30\3\31\3\31\3\31\3\31\3\31\3\32")
        buf.write("\3\32\3\32\3\32\3\32\3\32\3\32\3\32\3\32\3\32\3\32\3\32")
        buf.write("\3\32\3\32\3\32\3\32\3\32\5\32\u017f\n\32\3\32\3\32\3")
        buf.write("\32\3\32\3\32\3\32\3\32\3\32\3\32\3\32\3\32\3\32\3\32")
        buf.write("\3\32\3\32\7\32\u0190\n\32\f\32\16\32\u0193\13\32\3\33")
        buf.write("\5\33\u0196\n\33\3\33\3\33\3\33\3\33\3\33\3\33\5\33\u019e")
        buf.write("\n\33\3\33\3\33\3\33\3\33\3\33\7\33\u01a5\n\33\f\33\16")
        buf.write("\33\u01a8\13\33\3\33\3\33\3\33\3\33\5\33\u01ae\n\33\3")
        buf.write("\33\5\33\u01b1\n\33\3\34\3\34\3\34\3\34\3\34\3\34\3\34")
        buf.write("\5\34\u01ba\n\34\3\34\3\34\3\34\3\34\3\34\3\34\3\34\3")
        buf.write("\34\3\34\3\34\3\34\3\34\3\34\3\34\3\34\3\34\3\34\3\34")
        buf.write("\3\34\3\34\3\34\3\34\6\34\u01d2\n\34\r\34\16\34\u01d3")
        buf.write("\3\34\3\34\5\34\u01d8\n\34\3\35\3\35\3\35\3\35\3\35\3")
        buf.write("\35\3\35\3\35\3\35\3\35\3\35\3\35\3\35\3\35\3\35\5\35")
        buf.write("\u01e9\n\35\3\35\3\35\3\35\3\35\3\35\3\35\7\35\u01f1\n")
        buf.write("\35\f\35\16\35\u01f4\13\35\3\36\3\36\3\36\3\36\3\36\3")
        buf.write("\36\3\36\3\37\3\37\3\37\3\37\3\37\3\37\3\37\3\37\5\37")
        buf.write("\u0205\n\37\3 \3 \3 \3 \3 \5 \u020c\n \3!\3!\3!\3!\5!")
        buf.write("\u0212\n!\3\"\3\"\3\"\3\"\3#\3#\3#\3#\3#\3$\3$\3%\3%\3")
        buf.write("&\3&\3&\3&\3&\5&\u0226\n&\3\'\3\'\3\'\3\'\3\'\5\'\u022d")
        buf.write("\n\'\3(\3(\3(\3(\3(\3(\3(\3)\3)\3)\3)\3)\3*\3*\3+\3+\3")
        buf.write(",\3,\3,\3,\3,\3,\3,\3,\5,\u0247\n,\3-\3-\3-\3-\3-\3.\3")
        buf.write(".\3.\3.\3.\3/\3/\3/\3/\3/\7/\u0258\n/\f/\16/\u025b\13")
        buf.write("/\3/\3/\3\60\3\60\3\60\3\60\3\60\7\60\u0264\n\60\f\60")
        buf.write("\16\60\u0267\13\60\3\60\3\60\3\61\3\61\3\61\3\61\3\61")
        buf.write("\3\62\3\62\3\62\3\62\3\62\3\62\3\62\5\62\u0277\n\62\3")
        buf.write("\62\3\62\3\63\3\63\3\63\3\63\3\63\3\63\3\63\3\64\3\64")
        buf.write("\3\64\3\64\3\64\3\65\3\65\3\65\3\65\3\65\5\65\u028c\n")
        buf.write("\65\3\65\3\65\3\66\3\66\3\66\3\66\3\66\5\66\u0295\n\66")
        buf.write("\3\66\3\66\3\67\3\67\3\67\3\67\3\67\3\67\3\67\38\38\3")
        buf.write("9\39\3:\3:\3;\3;\3<\3<\3<\3<\3<\5<\u02ad\n<\3<\5<\u02b0")
        buf.write("\n<\3<\3<\3=\3=\3=\5=\u02b7\n=\3>\3>\5>\u02bb\n>\3>\3")
        buf.write(">\3>\5>\u02c0\n>\7>\u02c2\n>\f>\16>\u02c5\13>\3?\3?\3")
        buf.write("?\7?\u02ca\n?\f?\16?\u02cd\13?\3@\3@\3@\5@\u02d2\n@\3")
        buf.write("A\3A\3B\3B\3B\3B\3B\5B\u02db\nB\3C\3C\3D\5D\u02e0\nD\3")
        buf.write("D\3D\5D\u02e4\nD\3D\5D\u02e7\nD\3D\2\4\628E\2\4\6\b\n")
        buf.write("\f\16\20\22\24\26\30\32\34\36 \"$&(*,.\60\62\64\668:<")
        buf.write(">@BDFHJLNPRTVXZ\\^`bdfhjlnprtvxz|~\u0080\u0082\u0084\u0086")
        buf.write("\2\20\4\2\17\17,,\5\2\63\63SS{{\3\2\u0083\u0084\4\2\31")
        buf.write("\31PP\3\2\u008a\u0091\4\2\63\63{{\t\2((;;LLNOgg\u0086")
        buf.write("\u0086\u0089\u0089\3\2$&\3\2|}\r\2\t\n\20\22\33\34  *")
        buf.write("*\61\61\65\65FIjknouu\5\2QQ]]`a\5\2++bbee\13\2\23\23\"")
        buf.write("\"KKMM[\\prtt\u0082\u0082\u0085\u0085\3\2\u00a0\u00a2")
        buf.write("\2\u0321\2\u0088\3\2\2\2\4\u0095\3\2\2\2\6\u00a6\3\2\2")
        buf.write("\2\b\u00b7\3\2\2\2\n\u00b9\3\2\2\2\f\u00bf\3\2\2\2\16")
        buf.write("\u00c8\3\2\2\2\20\u00cb\3\2\2\2\22\u00d5\3\2\2\2\24\u00d8")
        buf.write("\3\2\2\2\26\u00e2\3\2\2\2\30\u00e5\3\2\2\2\32\u00e8\3")
        buf.write("\2\2\2\34\u0106\3\2\2\2\36\u0116\3\2\2\2 \u0118\3\2\2")
        buf.write("\2\"\u011f\3\2\2\2$\u0121\3\2\2\2&\u0139\3\2\2\2(\u0154")
        buf.write("\3\2\2\2*\u0156\3\2\2\2,\u015b\3\2\2\2.\u0163\3\2\2\2")
        buf.write("\60\u0168\3\2\2\2\62\u017e\3\2\2\2\64\u01b0\3\2\2\2\66")
        buf.write("\u01d7\3\2\2\28\u01e8\3\2\2\2:\u01f5\3\2\2\2<\u0204\3")
        buf.write("\2\2\2>\u0206\3\2\2\2@\u020d\3\2\2\2B\u0213\3\2\2\2D\u0217")
        buf.write("\3\2\2\2F\u021c\3\2\2\2H\u021e\3\2\2\2J\u0225\3\2\2\2")
        buf.write("L\u022c\3\2\2\2N\u022e\3\2\2\2P\u0235\3\2\2\2R\u023a\3")
        buf.write("\2\2\2T\u023c\3\2\2\2V\u0246\3\2\2\2X\u0248\3\2\2\2Z\u024d")
        buf.write("\3\2\2\2\\\u0252\3\2\2\2^\u025e\3\2\2\2`\u026a\3\2\2\2")
        buf.write("b\u026f\3\2\2\2d\u027a\3\2\2\2f\u0281\3\2\2\2h\u0286\3")
        buf.write("\2\2\2j\u028f\3\2\2\2l\u0298\3\2\2\2n\u029f\3\2\2\2p\u02a1")
        buf.write("\3\2\2\2r\u02a3\3\2\2\2t\u02a5\3\2\2\2v\u02a7\3\2\2\2")
        buf.write("x\u02b3\3\2\2\2z\u02ba\3\2\2\2|\u02c6\3\2\2\2~\u02ce\3")
        buf.write("\2\2\2\u0080\u02d3\3\2\2\2\u0082\u02da\3\2\2\2\u0084\u02dc")
        buf.write("\3\2\2\2\u0086\u02e6\3\2\2\2\u0088\u008d\5\4\3\2\u0089")
        buf.write("\u008a\7\3\2\2\u008a\u008c\5\4\3\2\u008b\u0089\3\2\2\2")
        buf.write("\u008c\u008f\3\2\2\2\u008d\u008b\3\2\2\2\u008d\u008e\3")
        buf.write("\2\2\2\u008e\u0091\3\2\2\2\u008f\u008d\3\2\2\2\u0090\u0092")
        buf.write("\7\3\2\2\u0091\u0090\3\2\2\2\u0091\u0092\3\2\2\2\u0092")
        buf.write("\u0093\3\2\2\2\u0093\u0094\7\2\2\3\u0094\3\3\2\2\2\u0095")
        buf.write("\u0096\5\n\6\2\u0096\u0098\5\f\7\2\u0097\u0099\5\16\b")
        buf.write("\2\u0098\u0097\3\2\2\2\u0098\u0099\3\2\2\2\u0099\u009b")
        buf.write("\3\2\2\2\u009a\u009c\5\20\t\2\u009b\u009a\3\2\2\2\u009b")
        buf.write("\u009c\3\2\2\2\u009c\u009e\3\2\2\2\u009d\u009f\5\22\n")
        buf.write("\2\u009e\u009d\3\2\2\2\u009e\u009f\3\2\2\2\u009f\u00a1")
        buf.write("\3\2\2\2\u00a0\u00a2\5\24\13\2\u00a1\u00a0\3\2\2\2\u00a1")
        buf.write("\u00a2\3\2\2\2\u00a2\u00a4\3\2\2\2\u00a3\u00a5\5\26\f")
        buf.write("\2\u00a4\u00a3\3\2\2\2\u00a4\u00a5\3\2\2\2\u00a5\5\3\2")
        buf.write("\2\2\u00a6\u00a7\7\4\2\2\u00a7\u00a8\5\n\6\2\u00a8\u00aa")
        buf.write("\5\f\7\2\u00a9\u00ab\5\16\b\2\u00aa\u00a9\3\2\2\2\u00aa")
        buf.write("\u00ab\3\2\2\2\u00ab\u00ad\3\2\2\2\u00ac\u00ae\5\20\t")
        buf.write("\2\u00ad\u00ac\3\2\2\2\u00ad\u00ae\3\2\2\2\u00ae\u00b0")
        buf.write("\3\2\2\2\u00af\u00b1\5\22\n\2\u00b0\u00af\3\2\2\2\u00b0")
        buf.write("\u00b1\3\2\2\2\u00b1\u00b3\3\2\2\2\u00b2\u00b4\5\24\13")
        buf.write("\2\u00b3\u00b2\3\2\2\2\u00b3\u00b4\3\2\2\2\u00b4\u00b5")
        buf.write("\3\2\2\2\u00b5\u00b6\7\5\2\2\u00b6\7\3\2\2\2\u00b7\u00b8")
        buf.write("\5\6\4\2\u00b8\t\3\2\2\2\u00b9\u00bb\7h\2\2\u00ba\u00bc")
        buf.write("\5\"\22\2\u00bb\u00ba\3\2\2\2\u00bb\u00bc\3\2\2\2\u00bc")
        buf.write("\u00bd\3\2\2\2\u00bd\u00be\5,\27\2\u00be\13\3\2\2\2\u00bf")
        buf.write("\u00c0\7\67\2\2\u00c0\u00c5\5$\23\2\u00c1\u00c2\7\6\2")
        buf.write("\2\u00c2\u00c4\5$\23\2\u00c3\u00c1\3\2\2\2\u00c4\u00c7")
        buf.write("\3\2\2\2\u00c5\u00c3\3\2\2\2\u00c5\u00c6\3\2\2\2\u00c6")
        buf.write("\r\3\2\2\2\u00c7\u00c5\3\2\2\2\u00c8\u00c9\7\u0088\2\2")
        buf.write("\u00c9\u00ca\58\35\2\u00ca\17\3\2\2\2\u00cb\u00cc\79\2")
        buf.write("\2\u00cc\u00cd\7\26\2\2\u00cd\u00d2\5\62\32\2\u00ce\u00cf")
        buf.write("\7\6\2\2\u00cf\u00d1\5\62\32\2\u00d0\u00ce\3\2\2\2\u00d1")
        buf.write("\u00d4\3\2\2\2\u00d2\u00d0\3\2\2\2\u00d2\u00d3\3\2\2\2")
        buf.write("\u00d3\21\3\2\2\2\u00d4\u00d2\3\2\2\2\u00d5\u00d6\7:\2")
        buf.write("\2\u00d6\u00d7\58\35\2\u00d7\23\3\2\2\2\u00d8\u00d9\7")
        buf.write("W\2\2\u00d9\u00da\7\26\2\2\u00da\u00df\5 \21\2\u00db\u00dc")
        buf.write("\7\6\2\2\u00dc\u00de\5 \21\2\u00dd\u00db\3\2\2\2\u00de")
        buf.write("\u00e1\3\2\2\2\u00df\u00dd\3\2\2\2\u00df\u00e0\3\2\2\2")
        buf.write("\u00e0\25\3\2\2\2\u00e1\u00df\3\2\2\2\u00e2\u00e3\7E\2")
        buf.write("\2\u00e3\u00e4\5\u0086D\2\u00e4\27\3\2\2\2\u00e5\u00e6")
        buf.write("\7y\2\2\u00e6\u00e7\5\u0086D\2\u00e7\31\3\2\2\2\u00e8")
        buf.write("\u00e9\5\34\17\2\u00e9\u00ea\7C\2\2\u00ea\u00ec\5&\24")
        buf.write("\2\u00eb\u00ed\5\36\20\2\u00ec\u00eb\3\2\2\2\u00ec\u00ed")
        buf.write("\3\2\2\2\u00ed\33\3\2\2\2\u00ee\u00f0\7?\2\2\u00ef\u00ee")
        buf.write("\3\2\2\2\u00ef\u00f0\3\2\2\2\u00f0\u0107\3\2\2\2\u00f1")
        buf.write("\u0107\7#\2\2\u00f2\u00f4\7D\2\2\u00f3\u00f5\7X\2\2\u00f4")
        buf.write("\u00f3\3\2\2\2\u00f4\u00f5\3\2\2\2\u00f5\u0107\3\2\2\2")
        buf.write("\u00f6\u00f8\7D\2\2\u00f7\u00f6\3\2\2\2\u00f7\u00f8\3")
        buf.write("\2\2\2\u00f8\u00f9\3\2\2\2\u00f9\u0107\7i\2\2\u00fa\u00fc")
        buf.write("\7c\2\2\u00fb\u00fd\7X\2\2\u00fc\u00fb\3\2\2\2\u00fc\u00fd")
        buf.write("\3\2\2\2\u00fd\u0107\3\2\2\2\u00fe\u0100\78\2\2\u00ff")
        buf.write("\u0101\7X\2\2\u0100\u00ff\3\2\2\2\u0100\u0101\3\2\2\2")
        buf.write("\u0101\u0107\3\2\2\2\u0102\u0104\7D\2\2\u0103\u0102\3")
        buf.write("\2\2\2\u0103\u0104\3\2\2\2\u0104\u0105\3\2\2\2\u0105\u0107")
        buf.write("\7\r\2\2\u0106\u00ef\3\2\2\2\u0106\u00f1\3\2\2\2\u0106")
        buf.write("\u00f2\3\2\2\2\u0106\u00f7\3\2\2\2\u0106\u00fa\3\2\2\2")
        buf.write("\u0106\u00fe\3\2\2\2\u0106\u0103\3\2\2\2\u0107\35\3\2")
        buf.write("\2\2\u0108\u0109\7U\2\2\u0109\u0117\58\35\2\u010a\u010b")
        buf.write("\7\u0081\2\2\u010b\u010c\7\4\2\2\u010c\u0111\5\u0084C")
        buf.write("\2\u010d\u010e\7\6\2\2\u010e\u0110\5\u0084C\2\u010f\u010d")
        buf.write("\3\2\2\2\u0110\u0113\3\2\2\2\u0111\u010f\3\2\2\2\u0111")
        buf.write("\u0112\3\2\2\2\u0112\u0114\3\2\2\2\u0113\u0111\3\2\2\2")
        buf.write("\u0114\u0115\7\5\2\2\u0115\u0117\3\2\2\2\u0116\u0108\3")
        buf.write("\2\2\2\u0116\u010a\3\2\2\2\u0117\37\3\2\2\2\u0118\u011a")
        buf.write("\5\62\32\2\u0119\u011b\t\2\2\2\u011a\u0119\3\2\2\2\u011a")
        buf.write("\u011b\3\2\2\2\u011b!\3\2\2\2\u011c\u0120\7-\2\2\u011d")
        buf.write("\u0120\7\13\2\2\u011e\u0120\5\30\r\2\u011f\u011c\3\2\2")
        buf.write("\2\u011f\u011d\3\2\2\2\u011f\u011e\3\2\2\2\u0120#\3\2")
        buf.write("\2\2\u0121\u0125\5&\24\2\u0122\u0124\5\32\16\2\u0123\u0122")
        buf.write("\3\2\2\2\u0124\u0127\3\2\2\2\u0125\u0123\3\2\2\2\u0125")
        buf.write("\u0126\3\2\2\2\u0126%\3\2\2\2\u0127\u0125\3\2\2\2\u0128")
        buf.write("\u012b\5\u0080A\2\u0129\u012a\7\16\2\2\u012a\u012c\5\u0084")
        buf.write("C\2\u012b\u0129\3\2\2\2\u012b\u012c\3\2\2\2\u012c\u013a")
        buf.write("\3\2\2\2\u012d\u0130\5\6\4\2\u012e\u012f\7\16\2\2\u012f")
        buf.write("\u0131\5\u0084C\2\u0130\u012e\3\2\2\2\u0130\u0131\3\2")
        buf.write("\2\2\u0131\u013a\3\2\2\2\u0132\u0133\7\4\2\2\u0133\u0134")
        buf.write("\5$\23\2\u0134\u0137\7\5\2\2\u0135\u0136\7\16\2\2\u0136")
        buf.write("\u0138\5\u0084C\2\u0137\u0135\3\2\2\2\u0137\u0138\3\2")
        buf.write("\2\2\u0138\u013a\3\2\2\2\u0139\u0128\3\2\2\2\u0139\u012d")
        buf.write("\3\2\2\2\u0139\u0132\3\2\2\2\u013a\'\3\2\2\2\u013b\u013c")
        buf.write("\7\27\2\2\u013c\u013e\5\62\32\2\u013d\u013f\5\60\31\2")
        buf.write("\u013e\u013d\3\2\2\2\u013f\u0140\3\2\2\2\u0140\u013e\3")
        buf.write("\2\2\2\u0140\u0141\3\2\2\2\u0141\u0144\3\2\2\2\u0142\u0143")
        buf.write("\7/\2\2\u0143\u0145\5\62\32\2\u0144\u0142\3\2\2\2\u0144")
        buf.write("\u0145\3\2\2\2\u0145\u0146\3\2\2\2\u0146\u0147\7\60\2")
        buf.write("\2\u0147\u0155\3\2\2\2\u0148\u014a\7\27\2\2\u0149\u014b")
        buf.write("\5.\30\2\u014a\u0149\3\2\2\2\u014b\u014c\3\2\2\2\u014c")
        buf.write("\u014a\3\2\2\2\u014c\u014d\3\2\2\2\u014d\u0150\3\2\2\2")
        buf.write("\u014e\u014f\7/\2\2\u014f\u0151\5\62\32\2\u0150\u014e")
        buf.write("\3\2\2\2\u0150\u0151\3\2\2\2\u0151\u0152\3\2\2\2\u0152")
        buf.write("\u0153\7\60\2\2\u0153\u0155\3\2\2\2\u0154\u013b\3\2\2")
        buf.write("\2\u0154\u0148\3\2\2\2\u0155)\3\2\2\2\u0156\u0159\5\62")
        buf.write("\32\2\u0157\u0158\7\16\2\2\u0158\u015a\5\u0084C\2\u0159")
        buf.write("\u0157\3\2\2\2\u0159\u015a\3\2\2\2\u015a+\3\2\2\2\u015b")
        buf.write("\u0160\5*\26\2\u015c\u015d\7\6\2\2\u015d\u015f\5*\26\2")
        buf.write("\u015e\u015c\3\2\2\2\u015f\u0162\3\2\2\2\u0160\u015e\3")
        buf.write("\2\2\2\u0160\u0161\3\2\2\2\u0161-\3\2\2\2\u0162\u0160")
        buf.write("\3\2\2\2\u0163\u0164\7\u0087\2\2\u0164\u0165\58\35\2\u0165")
        buf.write("\u0166\7v\2\2\u0166\u0167\5\62\32\2\u0167/\3\2\2\2\u0168")
        buf.write("\u0169\7\u0087\2\2\u0169\u016a\5\62\32\2\u016a\u016b\7")
        buf.write("v\2\2\u016b\u016c\5\62\32\2\u016c\61\3\2\2\2\u016d\u016e")
        buf.write("\b\32\1\2\u016e\u017f\5\u0082B\2\u016f\u017f\5(\25\2\u0170")
        buf.write("\u017f\5:\36\2\u0171\u017f\5J&\2\u0172\u017f\5L\'\2\u0173")
        buf.write("\u017f\5D#\2\u0174\u017f\5\66\34\2\u0175\u017f\5\b\5\2")
        buf.write("\u0176\u0177\7\4\2\2\u0177\u0178\5\62\32\2\u0178\u0179")
        buf.write("\7\5\2\2\u0179\u017f\3\2\2\2\u017a\u017f\5V,\2\u017b\u017f")
        buf.write("\5T+\2\u017c\u017f\5N(\2\u017d\u017f\5P)\2\u017e\u016d")
        buf.write("\3\2\2\2\u017e\u016f\3\2\2\2\u017e\u0170\3\2\2\2\u017e")
        buf.write("\u0171\3\2\2\2\u017e\u0172\3\2\2\2\u017e\u0173\3\2\2\2")
        buf.write("\u017e\u0174\3\2\2\2\u017e\u0175\3\2\2\2\u017e\u0176\3")
        buf.write("\2\2\2\u017e\u017a\3\2\2\2\u017e\u017b\3\2\2\2\u017e\u017c")
        buf.write("\3\2\2\2\u017e\u017d\3\2\2\2\u017f\u0191\3\2\2\2\u0180")
        buf.write("\u0181\f\23\2\2\u0181\u0182\7\u0094\2\2\u0182\u0190\5")
        buf.write("\62\32\24\u0183\u0184\f\22\2\2\u0184\u0185\7\u0095\2\2")
        buf.write("\u0185\u0190\5\62\32\23\u0186\u0187\f\21\2\2\u0187\u0188")
        buf.write("\7\u0096\2\2\u0188\u0190\5\62\32\22\u0189\u018a\f\20\2")
        buf.write("\2\u018a\u018b\7\u0092\2\2\u018b\u0190\5\62\32\21\u018c")
        buf.write("\u018d\f\17\2\2\u018d\u018e\7\u0093\2\2\u018e\u0190\5")
        buf.write("\62\32\20\u018f\u0180\3\2\2\2\u018f\u0183\3\2\2\2\u018f")
        buf.write("\u0186\3\2\2\2\u018f\u0189\3\2\2\2\u018f\u018c\3\2\2\2")
        buf.write("\u0190\u0193\3\2\2\2\u0191\u018f\3\2\2\2\u0191\u0192\3")
        buf.write("\2\2\2\u0192\63\3\2\2\2\u0193\u0191\3\2\2\2\u0194\u0196")
        buf.write("\7R\2\2\u0195\u0194\3\2\2\2\u0195\u0196\3\2\2\2\u0196")
        buf.write("\u0197\3\2\2\2\u0197\u0198\7\24\2\2\u0198\u0199\5\62\32")
        buf.write("\2\u0199\u019a\7\f\2\2\u019a\u019b\5\62\32\2\u019b\u01b1")
        buf.write("\3\2\2\2\u019c\u019e\7R\2\2\u019d\u019c\3\2\2\2\u019d")
        buf.write("\u019e\3\2\2\2\u019e\u019f\3\2\2\2\u019f\u01a0\7>\2\2")
        buf.write("\u01a0\u01a1\7\4\2\2\u01a1\u01a6\5\62\32\2\u01a2\u01a3")
        buf.write("\7\6\2\2\u01a3\u01a5\5\62\32\2\u01a4\u01a2\3\2\2\2\u01a5")
        buf.write("\u01a8\3\2\2\2\u01a6\u01a4\3\2\2\2\u01a6\u01a7\3\2\2\2")
        buf.write("\u01a7\u01a9\3\2\2\2\u01a8\u01a6\3\2\2\2\u01a9\u01aa\7")
        buf.write("\5\2\2\u01aa\u01b1\3\2\2\2\u01ab\u01ad\7B\2\2\u01ac\u01ae")
        buf.write("\7R\2\2\u01ad\u01ac\3\2\2\2\u01ad\u01ae\3\2\2\2\u01ae")
        buf.write("\u01af\3\2\2\2\u01af\u01b1\t\3\2\2\u01b0\u0195\3\2\2\2")
        buf.write("\u01b0\u019d\3\2\2\2\u01b0\u01ab\3\2\2\2\u01b1\65\3\2")
        buf.write("\2\2\u01b2\u01d8\5B\"\2\u01b3\u01d8\5j\66\2\u01b4\u01d8")
        buf.write("\5l\67\2\u01b5\u01d8\5h\65\2\u01b6\u01b7\5t;\2\u01b7\u01b9")
        buf.write("\7\4\2\2\u01b8\u01ba\5\"\22\2\u01b9\u01b8\3\2\2\2\u01b9")
        buf.write("\u01ba\3\2\2\2\u01ba\u01bb\3\2\2\2\u01bb\u01bc\5\62\32")
        buf.write("\2\u01bc\u01bd\7\5\2\2\u01bd\u01d8\3\2\2\2\u01be\u01bf")
        buf.write("\5n8\2\u01bf\u01c0\7\4\2\2\u01c0\u01c1\5\62\32\2\u01c1")
        buf.write("\u01c2\7\5\2\2\u01c2\u01d8\3\2\2\2\u01c3\u01c4\7=\2\2")
        buf.write("\u01c4\u01c5\7\4\2\2\u01c5\u01c6\58\35\2\u01c6\u01c7\7")
        buf.write("\6\2\2\u01c7\u01c8\5\62\32\2\u01c8\u01c9\7\6\2\2\u01c9")
        buf.write("\u01ca\5\62\32\2\u01ca\u01cb\7\5\2\2\u01cb\u01d8\3\2\2")
        buf.write("\2\u01cc\u01cd\7\35\2\2\u01cd\u01ce\7\4\2\2\u01ce\u01d1")
        buf.write("\5\62\32\2\u01cf\u01d0\7\6\2\2\u01d0\u01d2\5L\'\2\u01d1")
        buf.write("\u01cf\3\2\2\2\u01d2\u01d3\3\2\2\2\u01d3\u01d1\3\2\2\2")
        buf.write("\u01d3\u01d4\3\2\2\2\u01d4\u01d5\3\2\2\2\u01d5\u01d6\7")
        buf.write("\5\2\2\u01d6\u01d8\3\2\2\2\u01d7\u01b2\3\2\2\2\u01d7\u01b3")
        buf.write("\3\2\2\2\u01d7\u01b4\3\2\2\2\u01d7\u01b5\3\2\2\2\u01d7")
        buf.write("\u01b6\3\2\2\2\u01d7\u01be\3\2\2\2\u01d7\u01c3\3\2\2\2")
        buf.write("\u01d7\u01cc\3\2\2\2\u01d8\67\3\2\2\2\u01d9\u01da\b\35")
        buf.write("\1\2\u01da\u01db\7R\2\2\u01db\u01e9\58\35\t\u01dc\u01dd")
        buf.write("\5\62\32\2\u01dd\u01de\5F$\2\u01de\u01df\5\62\32\2\u01df")
        buf.write("\u01e9\3\2\2\2\u01e0\u01e1\7\4\2\2\u01e1\u01e2\58\35\2")
        buf.write("\u01e2\u01e3\7\5\2\2\u01e3\u01e9\3\2\2\2\u01e4\u01e5\5")
        buf.write("\62\32\2\u01e5\u01e6\5\64\33\2\u01e6\u01e9\3\2\2\2\u01e7")
        buf.write("\u01e9\5\u0082B\2\u01e8\u01d9\3\2\2\2\u01e8\u01dc\3\2")
        buf.write("\2\2\u01e8\u01e0\3\2\2\2\u01e8\u01e4\3\2\2\2\u01e8\u01e7")
        buf.write("\3\2\2\2\u01e9\u01f2\3\2\2\2\u01ea\u01eb\f\7\2\2\u01eb")
        buf.write("\u01ec\7\f\2\2\u01ec\u01f1\58\35\b\u01ed\u01ee\f\6\2\2")
        buf.write("\u01ee\u01ef\7V\2\2\u01ef\u01f1\58\35\7\u01f0\u01ea\3")
        buf.write("\2\2\2\u01f0\u01ed\3\2\2\2\u01f1\u01f4\3\2\2\2\u01f2\u01f0")
        buf.write("\3\2\2\2\u01f2\u01f3\3\2\2\2\u01f39\3\2\2\2\u01f4\u01f2")
        buf.write("\3\2\2\2\u01f5\u01f6\7\30\2\2\u01f6\u01f7\7\4\2\2\u01f7")
        buf.write("\u01f8\5\62\32\2\u01f8\u01f9\7\16\2\2\u01f9\u01fa\5<\37")
        buf.write("\2\u01fa\u01fb\7\5\2\2\u01fb;\3\2\2\2\u01fc\u0205\7@\2")
        buf.write("\2\u01fd\u0205\7\64\2\2\u01fe\u0205\7\25\2\2\u01ff\u0205")
        buf.write("\7x\2\2\u0200\u0205\7\'\2\2\u0201\u0205\7w\2\2\u0202\u0205")
        buf.write("\5> \2\u0203\u0205\5@!\2\u0204\u01fc\3\2\2\2\u0204\u01fd")
        buf.write("\3\2\2\2\u0204\u01fe\3\2\2\2\u0204\u01ff\3\2\2\2\u0204")
        buf.write("\u0200\3\2\2\2\u0204\u0201\3\2\2\2\u0204\u0202\3\2\2\2")
        buf.write("\u0204\u0203\3\2\2\2\u0205=\3\2\2\2\u0206\u020b\t\4\2")
        buf.write("\2\u0207\u0208\7\4\2\2\u0208\u020c\7\u009e\2\2\u0209\u020a")
        buf.write("\7K\2\2\u020a\u020c\7\5\2\2\u020b\u0207\3\2\2\2\u020b")
        buf.write("\u0209\3\2\2\2\u020b\u020c\3\2\2\2\u020c?\3\2\2\2\u020d")
        buf.write("\u0211\t\5\2\2\u020e\u020f\7\4\2\2\u020f\u0210\7\u009e")
        buf.write("\2\2\u0210\u0212\7\5\2\2\u0211\u020e\3\2\2\2\u0211\u0212")
        buf.write("\3\2\2\2\u0212A\3\2\2\2\u0213\u0214\5p9\2\u0214\u0215")
        buf.write("\7\4\2\2\u0215\u0216\7\5\2\2\u0216C\3\2\2\2\u0217\u0218")
        buf.write("\5r:\2\u0218\u0219\7\4\2\2\u0219\u021a\7\5\2\2\u021a\u021b")
        buf.write("\5v<\2\u021bE\3\2\2\2\u021c\u021d\t\6\2\2\u021dG\3\2\2")
        buf.write("\2\u021e\u021f\t\7\2\2\u021fI\3\2\2\2\u0220\u0226\7\u0094")
        buf.write("\2\2\u0221\u0222\5\u0084C\2\u0222\u0223\7\7\2\2\u0223")
        buf.write("\u0224\7\u0094\2\2\u0224\u0226\3\2\2\2\u0225\u0220\3\2")
        buf.write("\2\2\u0225\u0221\3\2\2\2\u0226K\3\2\2\2\u0227\u022d\7")
        buf.write("\u009d\2\2\u0228\u022d\5\u0086D\2\u0229\u022d\7{\2\2\u022a")
        buf.write("\u022d\7\63\2\2\u022b\u022d\7S\2\2\u022c\u0227\3\2\2\2")
        buf.write("\u022c\u0228\3\2\2\2\u022c\u0229\3\2\2\2\u022c\u022a\3")
        buf.write("\2\2\2\u022c\u022b\3\2\2\2\u022dM\3\2\2\2\u022e\u022f")
        buf.write("\7\62\2\2\u022f\u0230\7\4\2\2\u0230\u0231\5R*\2\u0231")
        buf.write("\u0232\7\67\2\2\u0232\u0233\5\62\32\2\u0233\u0234\7\5")
        buf.write("\2\2\u0234O\3\2\2\2\u0235\u0236\7)\2\2\u0236\u0237\7\4")
        buf.write("\2\2\u0237\u0238\5\62\32\2\u0238\u0239\7\5\2\2\u0239Q")
        buf.write("\3\2\2\2\u023a\u023b\t\b\2\2\u023bS\3\2\2\2\u023c\u023d")
        buf.write("\t\t\2\2\u023dU\3\2\2\2\u023e\u0247\5X-\2\u023f\u0247")
        buf.write("\5Z.\2\u0240\u0247\5\\/\2\u0241\u0247\5^\60\2\u0242\u0247")
        buf.write("\5`\61\2\u0243\u0247\5b\62\2\u0244\u0247\5d\63\2\u0245")
        buf.write("\u0247\5f\64\2\u0246\u023e\3\2\2\2\u0246\u023f\3\2\2\2")
        buf.write("\u0246\u0240\3\2\2\2\u0246\u0241\3\2\2\2\u0246\u0242\3")
        buf.write("\2\2\2\u0246\u0243\3\2\2\2\u0246\u0244\3\2\2\2\u0246\u0245")
        buf.write("\3\2\2\2\u0247W\3\2\2\2\u0248\u0249\7\u0080\2\2\u0249")
        buf.write("\u024a\7\4\2\2\u024a\u024b\5\62\32\2\u024b\u024c\7\5\2")
        buf.write("\2\u024cY\3\2\2\2\u024d\u024e\7J\2\2\u024e\u024f\7\4\2")
        buf.write("\2\u024f\u0250\5\62\32\2\u0250\u0251\7\5\2\2\u0251[\3")
        buf.write("\2\2\2\u0252\u0253\7\37\2\2\u0253\u0254\7\4\2\2\u0254")
        buf.write("\u0259\5\62\32\2\u0255\u0256\7\6\2\2\u0256\u0258\5\62")
        buf.write("\32\2\u0257\u0255\3\2\2\2\u0258\u025b\3\2\2\2\u0259\u0257")
        buf.write("\3\2\2\2\u0259\u025a\3\2\2\2\u025a\u025c\3\2\2\2\u025b")
        buf.write("\u0259\3\2\2\2\u025c\u025d\7\5\2\2\u025d]\3\2\2\2\u025e")
        buf.write("\u025f\7\36\2\2\u025f\u0260\7\4\2\2\u0260\u0265\5\62\32")
        buf.write("\2\u0261\u0262\7\6\2\2\u0262\u0264\5\62\32\2\u0263\u0261")
        buf.write("\3\2\2\2\u0264\u0267\3\2\2\2\u0265\u0263\3\2\2\2\u0265")
        buf.write("\u0266\3\2\2\2\u0266\u0268\3\2\2\2\u0267\u0265\3\2\2\2")
        buf.write("\u0268\u0269\7\5\2\2\u0269_\3\2\2\2\u026a\u026b\7z\2\2")
        buf.write("\u026b\u026c\7\4\2\2\u026c\u026d\5\62\32\2\u026d\u026e")
        buf.write("\7\5\2\2\u026ea\3\2\2\2\u026f\u0270\7s\2\2\u0270\u0271")
        buf.write("\7\4\2\2\u0271\u0272\5\62\32\2\u0272\u0273\7\67\2\2\u0273")
        buf.write("\u0276\5\62\32\2\u0274\u0275\7\66\2\2\u0275\u0277\5\62")
        buf.write("\32\2\u0276\u0274\3\2\2\2\u0276\u0277\3\2\2\2\u0277\u0278")
        buf.write("\3\2\2\2\u0278\u0279\7\5\2\2\u0279c\3\2\2\2\u027a\u027b")
        buf.write("\7^\2\2\u027b\u027c\7\4\2\2\u027c\u027d\5\62\32\2\u027d")
        buf.write("\u027e\7>\2\2\u027e\u027f\5\62\32\2\u027f\u0280\7\5\2")
        buf.write("\2\u0280e\3\2\2\2\u0281\u0282\7\32\2\2\u0282\u0283\7\4")
        buf.write("\2\2\u0283\u0284\5\62\32\2\u0284\u0285\7\5\2\2\u0285g")
        buf.write("\3\2\2\2\u0286\u0287\t\n\2\2\u0287\u0288\7\4\2\2\u0288")
        buf.write("\u028b\5\62\32\2\u0289\u028a\7\6\2\2\u028a\u028c\5\u0086")
        buf.write("D\2\u028b\u0289\3\2\2\2\u028b\u028c\3\2\2\2\u028c\u028d")
        buf.write("\3\2\2\2\u028d\u028e\7\5\2\2\u028ei\3\2\2\2\u028f\u0290")
        buf.write("\7d\2\2\u0290\u0291\7\4\2\2\u0291\u0294\5\62\32\2\u0292")
        buf.write("\u0293\7\6\2\2\u0293\u0295\5\u0086D\2\u0294\u0292\3\2")
        buf.write("\2\2\u0294\u0295\3\2\2\2\u0295\u0296\3\2\2\2\u0296\u0297")
        buf.write("\7\5\2\2\u0297k\3\2\2\2\u0298\u0299\7_\2\2\u0299\u029a")
        buf.write("\7\4\2\2\u029a\u029b\5\62\32\2\u029b\u029c\7\6\2\2\u029c")
        buf.write("\u029d\5\u0086D\2\u029d\u029e\7\5\2\2\u029em\3\2\2\2\u029f")
        buf.write("\u02a0\t\13\2\2\u02a0o\3\2\2\2\u02a1\u02a2\t\f\2\2\u02a2")
        buf.write("q\3\2\2\2\u02a3\u02a4\t\r\2\2\u02a4s\3\2\2\2\u02a5\u02a6")
        buf.write("\t\16\2\2\u02a6u\3\2\2\2\u02a7\u02a8\7Y\2\2\u02a8\u02ac")
        buf.write("\7\4\2\2\u02a9\u02aa\7Z\2\2\u02aa\u02ab\7\26\2\2\u02ab")
        buf.write("\u02ad\5\62\32\2\u02ac\u02a9\3\2\2\2\u02ac\u02ad\3\2\2")
        buf.write("\2\u02ad\u02af\3\2\2\2\u02ae\u02b0\5\24\13\2\u02af\u02ae")
        buf.write("\3\2\2\2\u02af\u02b0\3\2\2\2\u02b0\u02b1\3\2\2\2\u02b1")
        buf.write("\u02b2\7\5\2\2\u02b2w\3\2\2\2\u02b3\u02b6\5\6\4\2\u02b4")
        buf.write("\u02b5\7\16\2\2\u02b5\u02b7\5\u0084C\2\u02b6\u02b4\3\2")
        buf.write("\2\2\u02b6\u02b7\3\2\2\2\u02b7y\3\2\2\2\u02b8\u02bb\5")
        buf.write("~@\2\u02b9\u02bb\5x=\2\u02ba\u02b8\3\2\2\2\u02ba\u02b9")
        buf.write("\3\2\2\2\u02bb\u02c3\3\2\2\2\u02bc\u02bf\7\6\2\2\u02bd")
        buf.write("\u02c0\5~@\2\u02be\u02c0\5x=\2\u02bf\u02bd\3\2\2\2\u02bf")
        buf.write("\u02be\3\2\2\2\u02c0\u02c2\3\2\2\2\u02c1\u02bc\3\2\2\2")
        buf.write("\u02c2\u02c5\3\2\2\2\u02c3\u02c1\3\2\2\2\u02c3\u02c4\3")
        buf.write("\2\2\2\u02c4{\3\2\2\2\u02c5\u02c3\3\2\2\2\u02c6\u02cb")
        buf.write("\5~@\2\u02c7\u02c8\7\6\2\2\u02c8\u02ca\5~@\2\u02c9\u02c7")
        buf.write("\3\2\2\2\u02ca\u02cd\3\2\2\2\u02cb\u02c9\3\2\2\2\u02cb")
        buf.write("\u02cc\3\2\2\2\u02cc}\3\2\2\2\u02cd\u02cb\3\2\2\2\u02ce")
        buf.write("\u02d1\5\u0080A\2\u02cf\u02d0\7\16\2\2\u02d0\u02d2\5\u0084")
        buf.write("C\2\u02d1\u02cf\3\2\2\2\u02d1\u02d2\3\2\2\2\u02d2\177")
        buf.write("\3\2\2\2\u02d3\u02d4\t\17\2\2\u02d4\u0081\3\2\2\2\u02d5")
        buf.write("\u02db\7\u00a0\2\2\u02d6\u02db\7\u00a2\2\2\u02d7\u02d8")
        buf.write("\7\b\2\2\u02d8\u02d9\7\u009d\2\2\u02d9\u02db\7\b\2\2\u02da")
        buf.write("\u02d5\3\2\2\2\u02da\u02d6\3\2\2\2\u02da\u02d7\3\2\2\2")
        buf.write("\u02db\u0083\3\2\2\2\u02dc\u02dd\7\u00a2\2\2\u02dd\u0085")
        buf.write("\3\2\2\2\u02de\u02e0\7\u0093\2\2\u02df\u02de\3\2\2\2\u02df")
        buf.write("\u02e0\3\2\2\2\u02e0\u02e1\3\2\2\2\u02e1\u02e7\7\u009f")
        buf.write("\2\2\u02e2\u02e4\7\u0093\2\2\u02e3\u02e2\3\2\2\2\u02e3")
        buf.write("\u02e4\3\2\2\2\u02e4\u02e5\3\2\2\2\u02e5\u02e7\7\u009e")
        buf.write("\2\2\u02e6\u02df\3\2\2\2\u02e6\u02e3\3\2\2\2\u02e7\u0087")
        buf.write("\3\2\2\2N\u008d\u0091\u0098\u009b\u009e\u00a1\u00a4\u00aa")
        buf.write("\u00ad\u00b0\u00b3\u00bb\u00c5\u00d2\u00df\u00ec\u00ef")
        buf.write("\u00f4\u00f7\u00fc\u0100\u0103\u0106\u0111\u0116\u011a")
        buf.write("\u011f\u0125\u012b\u0130\u0137\u0139\u0140\u0144\u014c")
        buf.write("\u0150\u0154\u0159\u0160\u017e\u018f\u0191\u0195\u019d")
        buf.write("\u01a6\u01ad\u01b0\u01b9\u01d3\u01d7\u01e8\u01f0\u01f2")
        buf.write("\u0204\u020b\u0211\u0225\u022c\u0246\u0259\u0265\u0276")
        buf.write("\u028b\u0294\u02ac\u02af\u02b6\u02ba\u02bf\u02c3\u02cb")
        buf.write("\u02d1\u02da\u02df\u02e3\u02e6")
        return buf.getvalue()


class SqlSmallParser ( Parser ):

    grammarFileName = "SqlSmall.g4"

    atn = ATNDeserializer().deserialize(serializedATN())

    decisionsToDFA = [ DFA(ds, i) for i, ds in enumerate(atn.decisionToState) ]

    sharedContextCache = PredictionContextCache()

    literalNames = [ "<INVALID>", "';'", "'('", "')'", "','", "'.'", "'\"'", 
                     "<INVALID>", "<INVALID>", "<INVALID>", "<INVALID>", 
                     "<INVALID>", "<INVALID>", "<INVALID>", "<INVALID>", 
                     "<INVALID>", "<INVALID>", "<INVALID>", "<INVALID>", 
                     "<INVALID>", "<INVALID>", "<INVALID>", "<INVALID>", 
                     "<INVALID>", "<INVALID>", "<INVALID>", "<INVALID>", 
                     "<INVALID>", "<INVALID>", "<INVALID>", "<INVALID>", 
                     "<INVALID>", "<INVALID>", "<INVALID>", "<INVALID>", 
                     "<INVALID>", "<INVALID>", "<INVALID>", "<INVALID>", 
                     "<INVALID>", "<INVALID>", "<INVALID>", "<INVALID>", 
                     "<INVALID>", "<INVALID>", "<INVALID>", "<INVALID>", 
                     "<INVALID>", "<INVALID>", "<INVALID>", "<INVALID>", 
                     "<INVALID>", "<INVALID>", "<INVALID>", "<INVALID>", 
                     "<INVALID>", "<INVALID>", "<INVALID>", "<INVALID>", 
                     "<INVALID>", "<INVALID>", "<INVALID>", "<INVALID>", 
                     "<INVALID>", "<INVALID>", "<INVALID>", "<INVALID>", 
                     "<INVALID>", "<INVALID>", "<INVALID>", "<INVALID>", 
                     "<INVALID>", "<INVALID>", "<INVALID>", "<INVALID>", 
                     "<INVALID>", "<INVALID>", "<INVALID>", "<INVALID>", 
                     "<INVALID>", "<INVALID>", "<INVALID>", "<INVALID>", 
                     "<INVALID>", "<INVALID>", "<INVALID>", "<INVALID>", 
                     "<INVALID>", "<INVALID>", "<INVALID>", "<INVALID>", 
                     "<INVALID>", "<INVALID>", "<INVALID>", "<INVALID>", 
                     "<INVALID>", "<INVALID>", "<INVALID>", "<INVALID>", 
                     "<INVALID>", "<INVALID>", "<INVALID>", "<INVALID>", 
                     "<INVALID>", "<INVALID>", "<INVALID>", "<INVALID>", 
                     "<INVALID>", "<INVALID>", "<INVALID>", "<INVALID>", 
                     "<INVALID>", "<INVALID>", "<INVALID>", "<INVALID>", 
                     "<INVALID>", "<INVALID>", "<INVALID>", "<INVALID>", 
                     "<INVALID>", "<INVALID>", "<INVALID>", "<INVALID>", 
                     "<INVALID>", "<INVALID>", "<INVALID>", "<INVALID>", 
                     "<INVALID>", "<INVALID>", "<INVALID>", "<INVALID>", 
                     "<INVALID>", "<INVALID>", "<INVALID>", "<INVALID>", 
                     "<INVALID>", "<INVALID>", "'<=>'", "'<>'", "'!='", 
                     "'<'", "<INVALID>", "'>'", "<INVALID>", "'+'", "'-'", 
                     "'*'", "'/'", "'%'", "'~'", "'&'", "'|'", "'||'", "'^'", 
                     "'_'", "<INVALID>", "<INVALID>", "<INVALID>", "<INVALID>", 
                     "<INVALID>", "<INVALID>", "<INVALID>", "<INVALID>", 
                     "<INVALID>", "<INVALID>", "<INVALID>", "<INVALID>", 
                     "'/**/'" ]

    symbolicNames = [ "<INVALID>", "<INVALID>", "<INVALID>", "<INVALID>", 
                      "<INVALID>", "<INVALID>", "<INVALID>", "ABS", "ACOS", 
                      "ALL", "AND", "ANTI", "AS", "ASC", "ASIN", "ATAN", 
                      "ATANH", "AVG", "BETWEEN", "BOOLEAN", "BY", "CASE", 
                      "CAST", "CHAR", "CHAR_LENGTH", "CEIL", "CEILING", 
                      "CHOOSE", "COALESCE", "CONCAT", "COS", "COT", "COUNT", 
                      "CROSS", "CURRENT_DATE", "CURRENT_TIME", "CURRENT_TIMESTAMP", 
                      "DATE", "DAY", "DAYNAME", "DEGREES", "DENSE_RANK", 
                      "DESC", "DISTINCT", "DIV", "ELSE", "END", "EXP", "EXTRACT", 
                      "FALSE", "FLOAT", "FLOOR", "FOR", "FROM", "FULL", 
                      "GROUP", "HAVING", "HOUR", "IF", "IIF", "IN", "INNER", 
                      "INTEGER", "INTERSECT", "IS", "JOIN", "LEFT", "LIMIT", 
                      "LN", "LOG", "LOG10", "LOG2", "LOWER", "MAX", "MICROSECOND", 
                      "MIN", "MINUTE", "MONTH", "NCHAR", "NEWID", "NOT", 
                      "NULL", "NUMERIC", "ON", "OR", "ORDER", "OUTER", "OVER", 
                      "PARTITION", "PERCENTILE_CONT", "PERCENTILE_DISC", 
                      "PI", "POSITION", "POWER", "RAND", "RANDOM", "RANK", 
                      "RIGHT", "ROUND", "ROW_NUMBER", "ROWNUM", "SECOND", 
                      "SELECT", "SEMI", "SIGN", "SIN", "SORT", "SQL", "SQRT", 
                      "SQUARE", "STD", "STDDEV", "STDEV", "SUBSTRING", "SUM", 
                      "TAN", "THEN", "TIME", "TIMESTAMP", "TOP", "TRIM", 
                      "TRUE", "TRUNC", "TRUNCATE", "TZOFFSET", "UNION", 
                      "UPPER", "USING", "VAR", "VARCHAR", "NVARCHAR", "VARIANCE", 
                      "WEEKDAY", "WHEN", "WHERE", "YEAR", "EQ", "NSEQ", 
                      "NEQ", "NEQJ", "LT", "LTE", "GT", "GTE", "PLUS", "MINUS", 
                      "ASTERISK", "SLASH", "PERCENT", "TILDE", "AMPERSAND", 
                      "PIPE", "CONCAT_PIPE", "HAT", "UNDERSCORE", "STRING", 
                      "INTEGER_VALUE", "DECIMAL_VALUE", "QN2", "QN3", "IDENT", 
                      "IDENTIFIER_UNICODE", "IDENTIFIER", "ESCAPED_IDENTIFIER", 
                      "LETTER", "DOUBLEQ_STRING_LITERAL", "SIMPLE_COMMENT", 
                      "BRACKETED_EMPTY_COMMENT", "BRACKETED_COMMENT", "WS", 
                      "SPACE" ]

    RULE_batch = 0
    RULE_query = 1
    RULE_subquery = 2
    RULE_expressionSubquery = 3
    RULE_selectClause = 4
    RULE_fromClause = 5
    RULE_whereClause = 6
    RULE_aggregationClause = 7
    RULE_havingClause = 8
    RULE_orderClause = 9
    RULE_limitClause = 10
    RULE_topClause = 11
    RULE_joinRelation = 12
    RULE_joinType = 13
    RULE_joinCriteria = 14
    RULE_sortItem = 15
    RULE_setQuantifier = 16
    RULE_relation = 17
    RULE_relationPrimary = 18
    RULE_caseExpression = 19
    RULE_namedExpression = 20
    RULE_namedExpressionSeq = 21
    RULE_whenExpression = 22
    RULE_whenBaseExpression = 23
    RULE_expression = 24
    RULE_predicate = 25
    RULE_functionExpression = 26
    RULE_booleanExpression = 27
    RULE_castExpression = 28
    RULE_dbType = 29
    RULE_variableString = 30
    RULE_fixedString = 31
    RULE_bareFunction = 32
    RULE_rankingFunction = 33
    RULE_comparisonOperator = 34
    RULE_booleanValue = 35
    RULE_allExpression = 36
    RULE_literal = 37
    RULE_extractFunction = 38
    RULE_dayNameFunction = 39
    RULE_datePart = 40
    RULE_getTime = 41
    RULE_stringFunction = 42
    RULE_stringUpper = 43
    RULE_stringLower = 44
    RULE_stringConcat = 45
    RULE_coalesceFunction = 46
    RULE_trimFunction = 47
    RULE_substringFunction = 48
    RULE_positionFunction = 49
    RULE_charLengthFunction = 50
    RULE_truncFunction = 51
    RULE_roundFunction = 52
    RULE_powerFunction = 53
    RULE_mathFunctionName = 54
    RULE_bareFunctionName = 55
    RULE_rankingFunctionName = 56
    RULE_aggregateFunctionName = 57
    RULE_overClause = 58
    RULE_aliasedSubquery = 59
    RULE_aliasedTableOrSubquerySeq = 60
    RULE_aliasedTableSeq = 61
    RULE_aliasedTableName = 62
    RULE_qualifiedTableName = 63
    RULE_qualifiedColumnName = 64
    RULE_identifier = 65
    RULE_number = 66

    ruleNames =  [ "batch", "query", "subquery", "expressionSubquery", "selectClause", 
                   "fromClause", "whereClause", "aggregationClause", "havingClause", 
                   "orderClause", "limitClause", "topClause", "joinRelation", 
                   "joinType", "joinCriteria", "sortItem", "setQuantifier", 
                   "relation", "relationPrimary", "caseExpression", "namedExpression", 
                   "namedExpressionSeq", "whenExpression", "whenBaseExpression", 
                   "expression", "predicate", "functionExpression", "booleanExpression", 
                   "castExpression", "dbType", "variableString", "fixedString", 
                   "bareFunction", "rankingFunction", "comparisonOperator", 
                   "booleanValue", "allExpression", "literal", "extractFunction", 
                   "dayNameFunction", "datePart", "getTime", "stringFunction", 
                   "stringUpper", "stringLower", "stringConcat", "coalesceFunction", 
                   "trimFunction", "substringFunction", "positionFunction", 
                   "charLengthFunction", "truncFunction", "roundFunction", 
                   "powerFunction", "mathFunctionName", "bareFunctionName", 
                   "rankingFunctionName", "aggregateFunctionName", "overClause", 
                   "aliasedSubquery", "aliasedTableOrSubquerySeq", "aliasedTableSeq", 
                   "aliasedTableName", "qualifiedTableName", "qualifiedColumnName", 
                   "identifier", "number" ]

    EOF = Token.EOF
    T__0=1
    T__1=2
    T__2=3
    T__3=4
    T__4=5
    T__5=6
    ABS=7
    ACOS=8
    ALL=9
    AND=10
    ANTI=11
    AS=12
    ASC=13
    ASIN=14
    ATAN=15
    ATANH=16
    AVG=17
    BETWEEN=18
    BOOLEAN=19
    BY=20
    CASE=21
    CAST=22
    CHAR=23
    CHAR_LENGTH=24
    CEIL=25
    CEILING=26
    CHOOSE=27
    COALESCE=28
    CONCAT=29
    COS=30
    COT=31
    COUNT=32
    CROSS=33
    CURRENT_DATE=34
    CURRENT_TIME=35
    CURRENT_TIMESTAMP=36
    DATE=37
    DAY=38
    DAYNAME=39
    DEGREES=40
    DENSE_RANK=41
    DESC=42
    DISTINCT=43
    DIV=44
    ELSE=45
    END=46
    EXP=47
    EXTRACT=48
    FALSE=49
    FLOAT=50
    FLOOR=51
    FOR=52
    FROM=53
    FULL=54
    GROUP=55
    HAVING=56
    HOUR=57
    IF=58
    IIF=59
    IN=60
    INNER=61
    INTEGER=62
    INTERSECT=63
    IS=64
    JOIN=65
    LEFT=66
    LIMIT=67
    LN=68
    LOG=69
    LOG10=70
    LOG2=71
    LOWER=72
    MAX=73
    MICROSECOND=74
    MIN=75
    MINUTE=76
    MONTH=77
    NCHAR=78
    NEWID=79
    NOT=80
    NULL=81
    NUMERIC=82
    ON=83
    OR=84
    ORDER=85
    OUTER=86
    OVER=87
    PARTITION=88
    PERCENTILE_CONT=89
    PERCENTILE_DISC=90
    PI=91
    POSITION=92
    POWER=93
    RAND=94
    RANDOM=95
    RANK=96
    RIGHT=97
    ROUND=98
    ROW_NUMBER=99
    ROWNUM=100
    SECOND=101
    SELECT=102
    SEMI=103
    SIGN=104
    SIN=105
    SORT=106
    SQL=107
    SQRT=108
    SQUARE=109
    STD=110
    STDDEV=111
    STDEV=112
    SUBSTRING=113
    SUM=114
    TAN=115
    THEN=116
    TIME=117
    TIMESTAMP=118
    TOP=119
    TRIM=120
    TRUE=121
    TRUNC=122
    TRUNCATE=123
    TZOFFSET=124
    UNION=125
    UPPER=126
    USING=127
    VAR=128
    VARCHAR=129
    NVARCHAR=130
    VARIANCE=131
    WEEKDAY=132
    WHEN=133
    WHERE=134
    YEAR=135
    EQ=136
    NSEQ=137
    NEQ=138
    NEQJ=139
    LT=140
    LTE=141
    GT=142
    GTE=143
    PLUS=144
    MINUS=145
    ASTERISK=146
    SLASH=147
    PERCENT=148
    TILDE=149
    AMPERSAND=150
    PIPE=151
    CONCAT_PIPE=152
    HAT=153
    UNDERSCORE=154
    STRING=155
    INTEGER_VALUE=156
    DECIMAL_VALUE=157
    QN2=158
    QN3=159
    IDENT=160
    IDENTIFIER_UNICODE=161
    IDENTIFIER=162
    ESCAPED_IDENTIFIER=163
    LETTER=164
    DOUBLEQ_STRING_LITERAL=165
    SIMPLE_COMMENT=166
    BRACKETED_EMPTY_COMMENT=167
    BRACKETED_COMMENT=168
    WS=169
    SPACE=170

    def __init__(self, input:TokenStream, output:TextIO = sys.stdout):
        super().__init__(input, output)
        self.checkVersion("4.9.3")
        self._interp = ParserATNSimulator(self, self.atn, self.decisionsToDFA, self.sharedContextCache)
        self._predicates = None




    class BatchContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser

        def query(self, i:int=None):
            if i is None:
                return self.getTypedRuleContexts(SqlSmallParser.QueryContext)
            else:
                return self.getTypedRuleContext(SqlSmallParser.QueryContext,i)


        def EOF(self):
            return self.getToken(SqlSmallParser.EOF, 0)

        def getRuleIndex(self):
            return SqlSmallParser.RULE_batch

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterBatch" ):
                listener.enterBatch(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitBatch" ):
                listener.exitBatch(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitBatch" ):
                return visitor.visitBatch(self)
            else:
                return visitor.visitChildren(self)




    def batch(self):

        localctx = SqlSmallParser.BatchContext(self, self._ctx, self.state)
        self.enterRule(localctx, 0, self.RULE_batch)
        self._la = 0 # Token type
        try:
            self.enterOuterAlt(localctx, 1)
            self.state = 134
            self.query()
            self.state = 139
            self._errHandler.sync(self)
            _alt = self._interp.adaptivePredict(self._input,0,self._ctx)
            while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER:
                if _alt==1:
                    self.state = 135
                    self.match(SqlSmallParser.T__0)
                    self.state = 136
                    self.query() 
                self.state = 141
                self._errHandler.sync(self)
                _alt = self._interp.adaptivePredict(self._input,0,self._ctx)

            self.state = 143
            self._errHandler.sync(self)
            _la = self._input.LA(1)
            if _la==SqlSmallParser.T__0:
                self.state = 142
                self.match(SqlSmallParser.T__0)


            self.state = 145
            self.match(SqlSmallParser.EOF)
        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class QueryContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser

        def selectClause(self):
            return self.getTypedRuleContext(SqlSmallParser.SelectClauseContext,0)


        def fromClause(self):
            return self.getTypedRuleContext(SqlSmallParser.FromClauseContext,0)


        def whereClause(self):
            return self.getTypedRuleContext(SqlSmallParser.WhereClauseContext,0)


        def aggregationClause(self):
            return self.getTypedRuleContext(SqlSmallParser.AggregationClauseContext,0)


        def havingClause(self):
            return self.getTypedRuleContext(SqlSmallParser.HavingClauseContext,0)


        def orderClause(self):
            return self.getTypedRuleContext(SqlSmallParser.OrderClauseContext,0)


        def limitClause(self):
            return self.getTypedRuleContext(SqlSmallParser.LimitClauseContext,0)


        def getRuleIndex(self):
            return SqlSmallParser.RULE_query

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterQuery" ):
                listener.enterQuery(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitQuery" ):
                listener.exitQuery(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitQuery" ):
                return visitor.visitQuery(self)
            else:
                return visitor.visitChildren(self)




    def query(self):

        localctx = SqlSmallParser.QueryContext(self, self._ctx, self.state)
        self.enterRule(localctx, 2, self.RULE_query)
        self._la = 0 # Token type
        try:
            self.enterOuterAlt(localctx, 1)
            self.state = 147
            self.selectClause()
            self.state = 148
            self.fromClause()
            self.state = 150
            self._errHandler.sync(self)
            _la = self._input.LA(1)
            if _la==SqlSmallParser.WHERE:
                self.state = 149
                self.whereClause()


            self.state = 153
            self._errHandler.sync(self)
            _la = self._input.LA(1)
            if _la==SqlSmallParser.GROUP:
                self.state = 152
                self.aggregationClause()


            self.state = 156
            self._errHandler.sync(self)
            _la = self._input.LA(1)
            if _la==SqlSmallParser.HAVING:
                self.state = 155
                self.havingClause()


            self.state = 159
            self._errHandler.sync(self)
            _la = self._input.LA(1)
            if _la==SqlSmallParser.ORDER:
                self.state = 158
                self.orderClause()


            self.state = 162
            self._errHandler.sync(self)
            _la = self._input.LA(1)
            if _la==SqlSmallParser.LIMIT:
                self.state = 161
                self.limitClause()


        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class SubqueryContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser

        def selectClause(self):
            return self.getTypedRuleContext(SqlSmallParser.SelectClauseContext,0)


        def fromClause(self):
            return self.getTypedRuleContext(SqlSmallParser.FromClauseContext,0)


        def whereClause(self):
            return self.getTypedRuleContext(SqlSmallParser.WhereClauseContext,0)


        def aggregationClause(self):
            return self.getTypedRuleContext(SqlSmallParser.AggregationClauseContext,0)


        def havingClause(self):
            return self.getTypedRuleContext(SqlSmallParser.HavingClauseContext,0)


        def orderClause(self):
            return self.getTypedRuleContext(SqlSmallParser.OrderClauseContext,0)


        def getRuleIndex(self):
            return SqlSmallParser.RULE_subquery

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterSubquery" ):
                listener.enterSubquery(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitSubquery" ):
                listener.exitSubquery(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitSubquery" ):
                return visitor.visitSubquery(self)
            else:
                return visitor.visitChildren(self)




    def subquery(self):

        localctx = SqlSmallParser.SubqueryContext(self, self._ctx, self.state)
        self.enterRule(localctx, 4, self.RULE_subquery)
        self._la = 0 # Token type
        try:
            self.enterOuterAlt(localctx, 1)
            self.state = 164
            self.match(SqlSmallParser.T__1)
            self.state = 165
            self.selectClause()
            self.state = 166
            self.fromClause()
            self.state = 168
            self._errHandler.sync(self)
            _la = self._input.LA(1)
            if _la==SqlSmallParser.WHERE:
                self.state = 167
                self.whereClause()


            self.state = 171
            self._errHandler.sync(self)
            _la = self._input.LA(1)
            if _la==SqlSmallParser.GROUP:
                self.state = 170
                self.aggregationClause()


            self.state = 174
            self._errHandler.sync(self)
            _la = self._input.LA(1)
            if _la==SqlSmallParser.HAVING:
                self.state = 173
                self.havingClause()


            self.state = 177
            self._errHandler.sync(self)
            _la = self._input.LA(1)
            if _la==SqlSmallParser.ORDER:
                self.state = 176
                self.orderClause()


            self.state = 179
            self.match(SqlSmallParser.T__2)
        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class ExpressionSubqueryContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser

        def subquery(self):
            return self.getTypedRuleContext(SqlSmallParser.SubqueryContext,0)


        def getRuleIndex(self):
            return SqlSmallParser.RULE_expressionSubquery

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterExpressionSubquery" ):
                listener.enterExpressionSubquery(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitExpressionSubquery" ):
                listener.exitExpressionSubquery(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitExpressionSubquery" ):
                return visitor.visitExpressionSubquery(self)
            else:
                return visitor.visitChildren(self)




    def expressionSubquery(self):

        localctx = SqlSmallParser.ExpressionSubqueryContext(self, self._ctx, self.state)
        self.enterRule(localctx, 6, self.RULE_expressionSubquery)
        try:
            self.enterOuterAlt(localctx, 1)
            self.state = 181
            self.subquery()
        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class SelectClauseContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser

        def SELECT(self):
            return self.getToken(SqlSmallParser.SELECT, 0)

        def namedExpressionSeq(self):
            return self.getTypedRuleContext(SqlSmallParser.NamedExpressionSeqContext,0)


        def setQuantifier(self):
            return self.getTypedRuleContext(SqlSmallParser.SetQuantifierContext,0)


        def getRuleIndex(self):
            return SqlSmallParser.RULE_selectClause

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterSelectClause" ):
                listener.enterSelectClause(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitSelectClause" ):
                listener.exitSelectClause(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitSelectClause" ):
                return visitor.visitSelectClause(self)
            else:
                return visitor.visitChildren(self)




    def selectClause(self):

        localctx = SqlSmallParser.SelectClauseContext(self, self._ctx, self.state)
        self.enterRule(localctx, 8, self.RULE_selectClause)
        self._la = 0 # Token type
        try:
            self.enterOuterAlt(localctx, 1)
            self.state = 183
            self.match(SqlSmallParser.SELECT)
            self.state = 185
            self._errHandler.sync(self)
            _la = self._input.LA(1)
            if _la==SqlSmallParser.ALL or _la==SqlSmallParser.DISTINCT or _la==SqlSmallParser.TOP:
                self.state = 184
                self.setQuantifier()


            self.state = 187
            self.namedExpressionSeq()
        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class FromClauseContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser

        def FROM(self):
            return self.getToken(SqlSmallParser.FROM, 0)

        def relation(self, i:int=None):
            if i is None:
                return self.getTypedRuleContexts(SqlSmallParser.RelationContext)
            else:
                return self.getTypedRuleContext(SqlSmallParser.RelationContext,i)


        def getRuleIndex(self):
            return SqlSmallParser.RULE_fromClause

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterFromClause" ):
                listener.enterFromClause(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitFromClause" ):
                listener.exitFromClause(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitFromClause" ):
                return visitor.visitFromClause(self)
            else:
                return visitor.visitChildren(self)




    def fromClause(self):

        localctx = SqlSmallParser.FromClauseContext(self, self._ctx, self.state)
        self.enterRule(localctx, 10, self.RULE_fromClause)
        self._la = 0 # Token type
        try:
            self.enterOuterAlt(localctx, 1)
            self.state = 189
            self.match(SqlSmallParser.FROM)
            self.state = 190
            self.relation()
            self.state = 195
            self._errHandler.sync(self)
            _la = self._input.LA(1)
            while _la==SqlSmallParser.T__3:
                self.state = 191
                self.match(SqlSmallParser.T__3)
                self.state = 192
                self.relation()
                self.state = 197
                self._errHandler.sync(self)
                _la = self._input.LA(1)

        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class WhereClauseContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser

        def WHERE(self):
            return self.getToken(SqlSmallParser.WHERE, 0)

        def booleanExpression(self):
            return self.getTypedRuleContext(SqlSmallParser.BooleanExpressionContext,0)


        def getRuleIndex(self):
            return SqlSmallParser.RULE_whereClause

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterWhereClause" ):
                listener.enterWhereClause(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitWhereClause" ):
                listener.exitWhereClause(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitWhereClause" ):
                return visitor.visitWhereClause(self)
            else:
                return visitor.visitChildren(self)




    def whereClause(self):

        localctx = SqlSmallParser.WhereClauseContext(self, self._ctx, self.state)
        self.enterRule(localctx, 12, self.RULE_whereClause)
        try:
            self.enterOuterAlt(localctx, 1)
            self.state = 198
            self.match(SqlSmallParser.WHERE)
            self.state = 199
            self.booleanExpression(0)
        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class AggregationClauseContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser
            self._expression = None # ExpressionContext
            self.groupingExpressions = list() # of ExpressionContexts

        def GROUP(self):
            return self.getToken(SqlSmallParser.GROUP, 0)

        def BY(self):
            return self.getToken(SqlSmallParser.BY, 0)

        def expression(self, i:int=None):
            if i is None:
                return self.getTypedRuleContexts(SqlSmallParser.ExpressionContext)
            else:
                return self.getTypedRuleContext(SqlSmallParser.ExpressionContext,i)


        def getRuleIndex(self):
            return SqlSmallParser.RULE_aggregationClause

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterAggregationClause" ):
                listener.enterAggregationClause(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitAggregationClause" ):
                listener.exitAggregationClause(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitAggregationClause" ):
                return visitor.visitAggregationClause(self)
            else:
                return visitor.visitChildren(self)




    def aggregationClause(self):

        localctx = SqlSmallParser.AggregationClauseContext(self, self._ctx, self.state)
        self.enterRule(localctx, 14, self.RULE_aggregationClause)
        self._la = 0 # Token type
        try:
            self.enterOuterAlt(localctx, 1)
            self.state = 201
            self.match(SqlSmallParser.GROUP)
            self.state = 202
            self.match(SqlSmallParser.BY)
            self.state = 203
            localctx._expression = self.expression(0)
            localctx.groupingExpressions.append(localctx._expression)
            self.state = 208
            self._errHandler.sync(self)
            _la = self._input.LA(1)
            while _la==SqlSmallParser.T__3:
                self.state = 204
                self.match(SqlSmallParser.T__3)
                self.state = 205
                localctx._expression = self.expression(0)
                localctx.groupingExpressions.append(localctx._expression)
                self.state = 210
                self._errHandler.sync(self)
                _la = self._input.LA(1)

        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class HavingClauseContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser

        def HAVING(self):
            return self.getToken(SqlSmallParser.HAVING, 0)

        def booleanExpression(self):
            return self.getTypedRuleContext(SqlSmallParser.BooleanExpressionContext,0)


        def getRuleIndex(self):
            return SqlSmallParser.RULE_havingClause

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterHavingClause" ):
                listener.enterHavingClause(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitHavingClause" ):
                listener.exitHavingClause(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitHavingClause" ):
                return visitor.visitHavingClause(self)
            else:
                return visitor.visitChildren(self)




    def havingClause(self):

        localctx = SqlSmallParser.HavingClauseContext(self, self._ctx, self.state)
        self.enterRule(localctx, 16, self.RULE_havingClause)
        try:
            self.enterOuterAlt(localctx, 1)
            self.state = 211
            self.match(SqlSmallParser.HAVING)
            self.state = 212
            self.booleanExpression(0)
        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class OrderClauseContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser
            self._sortItem = None # SortItemContext
            self.order = list() # of SortItemContexts

        def ORDER(self):
            return self.getToken(SqlSmallParser.ORDER, 0)

        def BY(self):
            return self.getToken(SqlSmallParser.BY, 0)

        def sortItem(self, i:int=None):
            if i is None:
                return self.getTypedRuleContexts(SqlSmallParser.SortItemContext)
            else:
                return self.getTypedRuleContext(SqlSmallParser.SortItemContext,i)


        def getRuleIndex(self):
            return SqlSmallParser.RULE_orderClause

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterOrderClause" ):
                listener.enterOrderClause(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitOrderClause" ):
                listener.exitOrderClause(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitOrderClause" ):
                return visitor.visitOrderClause(self)
            else:
                return visitor.visitChildren(self)




    def orderClause(self):

        localctx = SqlSmallParser.OrderClauseContext(self, self._ctx, self.state)
        self.enterRule(localctx, 18, self.RULE_orderClause)
        self._la = 0 # Token type
        try:
            self.enterOuterAlt(localctx, 1)
            self.state = 214
            self.match(SqlSmallParser.ORDER)
            self.state = 215
            self.match(SqlSmallParser.BY)
            self.state = 216
            localctx._sortItem = self.sortItem()
            localctx.order.append(localctx._sortItem)
            self.state = 221
            self._errHandler.sync(self)
            _la = self._input.LA(1)
            while _la==SqlSmallParser.T__3:
                self.state = 217
                self.match(SqlSmallParser.T__3)
                self.state = 218
                localctx._sortItem = self.sortItem()
                localctx.order.append(localctx._sortItem)
                self.state = 223
                self._errHandler.sync(self)
                _la = self._input.LA(1)

        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class LimitClauseContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser
            self.n = None # NumberContext

        def LIMIT(self):
            return self.getToken(SqlSmallParser.LIMIT, 0)

        def number(self):
            return self.getTypedRuleContext(SqlSmallParser.NumberContext,0)


        def getRuleIndex(self):
            return SqlSmallParser.RULE_limitClause

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterLimitClause" ):
                listener.enterLimitClause(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitLimitClause" ):
                listener.exitLimitClause(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitLimitClause" ):
                return visitor.visitLimitClause(self)
            else:
                return visitor.visitChildren(self)




    def limitClause(self):

        localctx = SqlSmallParser.LimitClauseContext(self, self._ctx, self.state)
        self.enterRule(localctx, 20, self.RULE_limitClause)
        try:
            self.enterOuterAlt(localctx, 1)
            self.state = 224
            self.match(SqlSmallParser.LIMIT)
            self.state = 225
            localctx.n = self.number()
        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class TopClauseContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser
            self.n = None # NumberContext

        def TOP(self):
            return self.getToken(SqlSmallParser.TOP, 0)

        def number(self):
            return self.getTypedRuleContext(SqlSmallParser.NumberContext,0)


        def getRuleIndex(self):
            return SqlSmallParser.RULE_topClause

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterTopClause" ):
                listener.enterTopClause(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitTopClause" ):
                listener.exitTopClause(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitTopClause" ):
                return visitor.visitTopClause(self)
            else:
                return visitor.visitChildren(self)




    def topClause(self):

        localctx = SqlSmallParser.TopClauseContext(self, self._ctx, self.state)
        self.enterRule(localctx, 22, self.RULE_topClause)
        try:
            self.enterOuterAlt(localctx, 1)
            self.state = 227
            self.match(SqlSmallParser.TOP)
            self.state = 228
            localctx.n = self.number()
        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class JoinRelationContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser
            self.right = None # RelationPrimaryContext

        def JOIN(self):
            return self.getToken(SqlSmallParser.JOIN, 0)

        def relationPrimary(self):
            return self.getTypedRuleContext(SqlSmallParser.RelationPrimaryContext,0)


        def joinType(self):
            return self.getTypedRuleContext(SqlSmallParser.JoinTypeContext,0)


        def joinCriteria(self):
            return self.getTypedRuleContext(SqlSmallParser.JoinCriteriaContext,0)


        def getRuleIndex(self):
            return SqlSmallParser.RULE_joinRelation

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterJoinRelation" ):
                listener.enterJoinRelation(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitJoinRelation" ):
                listener.exitJoinRelation(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitJoinRelation" ):
                return visitor.visitJoinRelation(self)
            else:
                return visitor.visitChildren(self)




    def joinRelation(self):

        localctx = SqlSmallParser.JoinRelationContext(self, self._ctx, self.state)
        self.enterRule(localctx, 24, self.RULE_joinRelation)
        self._la = 0 # Token type
        try:
            self.enterOuterAlt(localctx, 1)
            self.state = 230
            self.joinType()
            self.state = 231
            self.match(SqlSmallParser.JOIN)
            self.state = 232
            localctx.right = self.relationPrimary()
            self.state = 234
            self._errHandler.sync(self)
            _la = self._input.LA(1)
            if _la==SqlSmallParser.ON or _la==SqlSmallParser.USING:
                self.state = 233
                self.joinCriteria()


        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class JoinTypeContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser

        def INNER(self):
            return self.getToken(SqlSmallParser.INNER, 0)

        def CROSS(self):
            return self.getToken(SqlSmallParser.CROSS, 0)

        def LEFT(self):
            return self.getToken(SqlSmallParser.LEFT, 0)

        def OUTER(self):
            return self.getToken(SqlSmallParser.OUTER, 0)

        def SEMI(self):
            return self.getToken(SqlSmallParser.SEMI, 0)

        def RIGHT(self):
            return self.getToken(SqlSmallParser.RIGHT, 0)

        def FULL(self):
            return self.getToken(SqlSmallParser.FULL, 0)

        def ANTI(self):
            return self.getToken(SqlSmallParser.ANTI, 0)

        def getRuleIndex(self):
            return SqlSmallParser.RULE_joinType

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterJoinType" ):
                listener.enterJoinType(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitJoinType" ):
                listener.exitJoinType(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitJoinType" ):
                return visitor.visitJoinType(self)
            else:
                return visitor.visitChildren(self)




    def joinType(self):

        localctx = SqlSmallParser.JoinTypeContext(self, self._ctx, self.state)
        self.enterRule(localctx, 26, self.RULE_joinType)
        self._la = 0 # Token type
        try:
            self.state = 260
            self._errHandler.sync(self)
            la_ = self._interp.adaptivePredict(self._input,22,self._ctx)
            if la_ == 1:
                self.enterOuterAlt(localctx, 1)
                self.state = 237
                self._errHandler.sync(self)
                _la = self._input.LA(1)
                if _la==SqlSmallParser.INNER:
                    self.state = 236
                    self.match(SqlSmallParser.INNER)


                pass

            elif la_ == 2:
                self.enterOuterAlt(localctx, 2)
                self.state = 239
                self.match(SqlSmallParser.CROSS)
                pass

            elif la_ == 3:
                self.enterOuterAlt(localctx, 3)
                self.state = 240
                self.match(SqlSmallParser.LEFT)
                self.state = 242
                self._errHandler.sync(self)
                _la = self._input.LA(1)
                if _la==SqlSmallParser.OUTER:
                    self.state = 241
                    self.match(SqlSmallParser.OUTER)


                pass

            elif la_ == 4:
                self.enterOuterAlt(localctx, 4)
                self.state = 245
                self._errHandler.sync(self)
                _la = self._input.LA(1)
                if _la==SqlSmallParser.LEFT:
                    self.state = 244
                    self.match(SqlSmallParser.LEFT)


                self.state = 247
                self.match(SqlSmallParser.SEMI)
                pass

            elif la_ == 5:
                self.enterOuterAlt(localctx, 5)
                self.state = 248
                self.match(SqlSmallParser.RIGHT)
                self.state = 250
                self._errHandler.sync(self)
                _la = self._input.LA(1)
                if _la==SqlSmallParser.OUTER:
                    self.state = 249
                    self.match(SqlSmallParser.OUTER)


                pass

            elif la_ == 6:
                self.enterOuterAlt(localctx, 6)
                self.state = 252
                self.match(SqlSmallParser.FULL)
                self.state = 254
                self._errHandler.sync(self)
                _la = self._input.LA(1)
                if _la==SqlSmallParser.OUTER:
                    self.state = 253
                    self.match(SqlSmallParser.OUTER)


                pass

            elif la_ == 7:
                self.enterOuterAlt(localctx, 7)
                self.state = 257
                self._errHandler.sync(self)
                _la = self._input.LA(1)
                if _la==SqlSmallParser.LEFT:
                    self.state = 256
                    self.match(SqlSmallParser.LEFT)


                self.state = 259
                self.match(SqlSmallParser.ANTI)
                pass


        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class JoinCriteriaContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser


        def getRuleIndex(self):
            return SqlSmallParser.RULE_joinCriteria

     
        def copyFrom(self, ctx:ParserRuleContext):
            super().copyFrom(ctx)



    class BooleanJoinContext(JoinCriteriaContext):

        def __init__(self, parser, ctx:ParserRuleContext): # actually a SqlSmallParser.JoinCriteriaContext
            super().__init__(parser)
            self.copyFrom(ctx)

        def ON(self):
            return self.getToken(SqlSmallParser.ON, 0)
        def booleanExpression(self):
            return self.getTypedRuleContext(SqlSmallParser.BooleanExpressionContext,0)


        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterBooleanJoin" ):
                listener.enterBooleanJoin(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitBooleanJoin" ):
                listener.exitBooleanJoin(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitBooleanJoin" ):
                return visitor.visitBooleanJoin(self)
            else:
                return visitor.visitChildren(self)


    class UsingJoinContext(JoinCriteriaContext):

        def __init__(self, parser, ctx:ParserRuleContext): # actually a SqlSmallParser.JoinCriteriaContext
            super().__init__(parser)
            self.copyFrom(ctx)

        def USING(self):
            return self.getToken(SqlSmallParser.USING, 0)
        def identifier(self, i:int=None):
            if i is None:
                return self.getTypedRuleContexts(SqlSmallParser.IdentifierContext)
            else:
                return self.getTypedRuleContext(SqlSmallParser.IdentifierContext,i)


        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterUsingJoin" ):
                listener.enterUsingJoin(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitUsingJoin" ):
                listener.exitUsingJoin(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitUsingJoin" ):
                return visitor.visitUsingJoin(self)
            else:
                return visitor.visitChildren(self)



    def joinCriteria(self):

        localctx = SqlSmallParser.JoinCriteriaContext(self, self._ctx, self.state)
        self.enterRule(localctx, 28, self.RULE_joinCriteria)
        self._la = 0 # Token type
        try:
            self.state = 276
            self._errHandler.sync(self)
            token = self._input.LA(1)
            if token in [SqlSmallParser.ON]:
                localctx = SqlSmallParser.BooleanJoinContext(self, localctx)
                self.enterOuterAlt(localctx, 1)
                self.state = 262
                self.match(SqlSmallParser.ON)
                self.state = 263
                self.booleanExpression(0)
                pass
            elif token in [SqlSmallParser.USING]:
                localctx = SqlSmallParser.UsingJoinContext(self, localctx)
                self.enterOuterAlt(localctx, 2)
                self.state = 264
                self.match(SqlSmallParser.USING)
                self.state = 265
                self.match(SqlSmallParser.T__1)
                self.state = 266
                self.identifier()
                self.state = 271
                self._errHandler.sync(self)
                _la = self._input.LA(1)
                while _la==SqlSmallParser.T__3:
                    self.state = 267
                    self.match(SqlSmallParser.T__3)
                    self.state = 268
                    self.identifier()
                    self.state = 273
                    self._errHandler.sync(self)
                    _la = self._input.LA(1)

                self.state = 274
                self.match(SqlSmallParser.T__2)
                pass
            else:
                raise NoViableAltException(self)

        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class SortItemContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser
            self.ordering = None # Token

        def expression(self):
            return self.getTypedRuleContext(SqlSmallParser.ExpressionContext,0)


        def ASC(self):
            return self.getToken(SqlSmallParser.ASC, 0)

        def DESC(self):
            return self.getToken(SqlSmallParser.DESC, 0)

        def getRuleIndex(self):
            return SqlSmallParser.RULE_sortItem

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterSortItem" ):
                listener.enterSortItem(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitSortItem" ):
                listener.exitSortItem(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitSortItem" ):
                return visitor.visitSortItem(self)
            else:
                return visitor.visitChildren(self)




    def sortItem(self):

        localctx = SqlSmallParser.SortItemContext(self, self._ctx, self.state)
        self.enterRule(localctx, 30, self.RULE_sortItem)
        self._la = 0 # Token type
        try:
            self.enterOuterAlt(localctx, 1)
            self.state = 278
            self.expression(0)
            self.state = 280
            self._errHandler.sync(self)
            _la = self._input.LA(1)
            if _la==SqlSmallParser.ASC or _la==SqlSmallParser.DESC:
                self.state = 279
                localctx.ordering = self._input.LT(1)
                _la = self._input.LA(1)
                if not(_la==SqlSmallParser.ASC or _la==SqlSmallParser.DESC):
                    localctx.ordering = self._errHandler.recoverInline(self)
                else:
                    self._errHandler.reportMatch(self)
                    self.consume()


        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class SetQuantifierContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser

        def DISTINCT(self):
            return self.getToken(SqlSmallParser.DISTINCT, 0)

        def ALL(self):
            return self.getToken(SqlSmallParser.ALL, 0)

        def topClause(self):
            return self.getTypedRuleContext(SqlSmallParser.TopClauseContext,0)


        def getRuleIndex(self):
            return SqlSmallParser.RULE_setQuantifier

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterSetQuantifier" ):
                listener.enterSetQuantifier(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitSetQuantifier" ):
                listener.exitSetQuantifier(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitSetQuantifier" ):
                return visitor.visitSetQuantifier(self)
            else:
                return visitor.visitChildren(self)




    def setQuantifier(self):

        localctx = SqlSmallParser.SetQuantifierContext(self, self._ctx, self.state)
        self.enterRule(localctx, 32, self.RULE_setQuantifier)
        try:
            self.state = 285
            self._errHandler.sync(self)
            token = self._input.LA(1)
            if token in [SqlSmallParser.DISTINCT]:
                self.enterOuterAlt(localctx, 1)
                self.state = 282
                self.match(SqlSmallParser.DISTINCT)
                pass
            elif token in [SqlSmallParser.ALL]:
                self.enterOuterAlt(localctx, 2)
                self.state = 283
                self.match(SqlSmallParser.ALL)
                pass
            elif token in [SqlSmallParser.TOP]:
                self.enterOuterAlt(localctx, 3)
                self.state = 284
                self.topClause()
                pass
            else:
                raise NoViableAltException(self)

        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class RelationContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser

        def relationPrimary(self):
            return self.getTypedRuleContext(SqlSmallParser.RelationPrimaryContext,0)


        def joinRelation(self, i:int=None):
            if i is None:
                return self.getTypedRuleContexts(SqlSmallParser.JoinRelationContext)
            else:
                return self.getTypedRuleContext(SqlSmallParser.JoinRelationContext,i)


        def getRuleIndex(self):
            return SqlSmallParser.RULE_relation

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterRelation" ):
                listener.enterRelation(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitRelation" ):
                listener.exitRelation(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitRelation" ):
                return visitor.visitRelation(self)
            else:
                return visitor.visitChildren(self)




    def relation(self):

        localctx = SqlSmallParser.RelationContext(self, self._ctx, self.state)
        self.enterRule(localctx, 34, self.RULE_relation)
        self._la = 0 # Token type
        try:
            self.enterOuterAlt(localctx, 1)
            self.state = 287
            self.relationPrimary()
            self.state = 291
            self._errHandler.sync(self)
            _la = self._input.LA(1)
            while (((_la) & ~0x3f) == 0 and ((1 << _la) & ((1 << SqlSmallParser.ANTI) | (1 << SqlSmallParser.CROSS) | (1 << SqlSmallParser.FULL) | (1 << SqlSmallParser.INNER))) != 0) or ((((_la - 65)) & ~0x3f) == 0 and ((1 << (_la - 65)) & ((1 << (SqlSmallParser.JOIN - 65)) | (1 << (SqlSmallParser.LEFT - 65)) | (1 << (SqlSmallParser.RIGHT - 65)) | (1 << (SqlSmallParser.SEMI - 65)))) != 0):
                self.state = 288
                self.joinRelation()
                self.state = 293
                self._errHandler.sync(self)
                _la = self._input.LA(1)

        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class RelationPrimaryContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser


        def getRuleIndex(self):
            return SqlSmallParser.RULE_relationPrimary

     
        def copyFrom(self, ctx:ParserRuleContext):
            super().copyFrom(ctx)



    class AliasedRelationContext(RelationPrimaryContext):

        def __init__(self, parser, ctx:ParserRuleContext): # actually a SqlSmallParser.RelationPrimaryContext
            super().__init__(parser)
            self.alias = None # IdentifierContext
            self.copyFrom(ctx)

        def relation(self):
            return self.getTypedRuleContext(SqlSmallParser.RelationContext,0)

        def AS(self):
            return self.getToken(SqlSmallParser.AS, 0)
        def identifier(self):
            return self.getTypedRuleContext(SqlSmallParser.IdentifierContext,0)


        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterAliasedRelation" ):
                listener.enterAliasedRelation(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitAliasedRelation" ):
                listener.exitAliasedRelation(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitAliasedRelation" ):
                return visitor.visitAliasedRelation(self)
            else:
                return visitor.visitChildren(self)


    class AliasedQueryContext(RelationPrimaryContext):

        def __init__(self, parser, ctx:ParserRuleContext): # actually a SqlSmallParser.RelationPrimaryContext
            super().__init__(parser)
            self.alias = None # IdentifierContext
            self.copyFrom(ctx)

        def subquery(self):
            return self.getTypedRuleContext(SqlSmallParser.SubqueryContext,0)

        def AS(self):
            return self.getToken(SqlSmallParser.AS, 0)
        def identifier(self):
            return self.getTypedRuleContext(SqlSmallParser.IdentifierContext,0)


        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterAliasedQuery" ):
                listener.enterAliasedQuery(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitAliasedQuery" ):
                listener.exitAliasedQuery(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitAliasedQuery" ):
                return visitor.visitAliasedQuery(self)
            else:
                return visitor.visitChildren(self)


    class TableContext(RelationPrimaryContext):

        def __init__(self, parser, ctx:ParserRuleContext): # actually a SqlSmallParser.RelationPrimaryContext
            super().__init__(parser)
            self.alias = None # IdentifierContext
            self.copyFrom(ctx)

        def qualifiedTableName(self):
            return self.getTypedRuleContext(SqlSmallParser.QualifiedTableNameContext,0)

        def AS(self):
            return self.getToken(SqlSmallParser.AS, 0)
        def identifier(self):
            return self.getTypedRuleContext(SqlSmallParser.IdentifierContext,0)


        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterTable" ):
                listener.enterTable(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitTable" ):
                listener.exitTable(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitTable" ):
                return visitor.visitTable(self)
            else:
                return visitor.visitChildren(self)



    def relationPrimary(self):

        localctx = SqlSmallParser.RelationPrimaryContext(self, self._ctx, self.state)
        self.enterRule(localctx, 36, self.RULE_relationPrimary)
        self._la = 0 # Token type
        try:
            self.state = 311
            self._errHandler.sync(self)
            la_ = self._interp.adaptivePredict(self._input,31,self._ctx)
            if la_ == 1:
                localctx = SqlSmallParser.TableContext(self, localctx)
                self.enterOuterAlt(localctx, 1)
                self.state = 294
                self.qualifiedTableName()
                self.state = 297
                self._errHandler.sync(self)
                _la = self._input.LA(1)
                if _la==SqlSmallParser.AS:
                    self.state = 295
                    self.match(SqlSmallParser.AS)
                    self.state = 296
                    localctx.alias = self.identifier()


                pass

            elif la_ == 2:
                localctx = SqlSmallParser.AliasedQueryContext(self, localctx)
                self.enterOuterAlt(localctx, 2)
                self.state = 299
                self.subquery()
                self.state = 302
                self._errHandler.sync(self)
                _la = self._input.LA(1)
                if _la==SqlSmallParser.AS:
                    self.state = 300
                    self.match(SqlSmallParser.AS)
                    self.state = 301
                    localctx.alias = self.identifier()


                pass

            elif la_ == 3:
                localctx = SqlSmallParser.AliasedRelationContext(self, localctx)
                self.enterOuterAlt(localctx, 3)
                self.state = 304
                self.match(SqlSmallParser.T__1)
                self.state = 305
                self.relation()
                self.state = 306
                self.match(SqlSmallParser.T__2)
                self.state = 309
                self._errHandler.sync(self)
                _la = self._input.LA(1)
                if _la==SqlSmallParser.AS:
                    self.state = 307
                    self.match(SqlSmallParser.AS)
                    self.state = 308
                    localctx.alias = self.identifier()


                pass


        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class CaseExpressionContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser


        def getRuleIndex(self):
            return SqlSmallParser.RULE_caseExpression

     
        def copyFrom(self, ctx:ParserRuleContext):
            super().copyFrom(ctx)



    class CaseWhenExprContext(CaseExpressionContext):

        def __init__(self, parser, ctx:ParserRuleContext): # actually a SqlSmallParser.CaseExpressionContext
            super().__init__(parser)
            self.elseExpr = None # ExpressionContext
            self.copyFrom(ctx)

        def CASE(self):
            return self.getToken(SqlSmallParser.CASE, 0)
        def END(self):
            return self.getToken(SqlSmallParser.END, 0)
        def whenExpression(self, i:int=None):
            if i is None:
                return self.getTypedRuleContexts(SqlSmallParser.WhenExpressionContext)
            else:
                return self.getTypedRuleContext(SqlSmallParser.WhenExpressionContext,i)

        def ELSE(self):
            return self.getToken(SqlSmallParser.ELSE, 0)
        def expression(self):
            return self.getTypedRuleContext(SqlSmallParser.ExpressionContext,0)


        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterCaseWhenExpr" ):
                listener.enterCaseWhenExpr(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitCaseWhenExpr" ):
                listener.exitCaseWhenExpr(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitCaseWhenExpr" ):
                return visitor.visitCaseWhenExpr(self)
            else:
                return visitor.visitChildren(self)


    class CaseBaseExprContext(CaseExpressionContext):

        def __init__(self, parser, ctx:ParserRuleContext): # actually a SqlSmallParser.CaseExpressionContext
            super().__init__(parser)
            self.baseCaseExpr = None # ExpressionContext
            self.elseExpr = None # ExpressionContext
            self.copyFrom(ctx)

        def CASE(self):
            return self.getToken(SqlSmallParser.CASE, 0)
        def END(self):
            return self.getToken(SqlSmallParser.END, 0)
        def expression(self, i:int=None):
            if i is None:
                return self.getTypedRuleContexts(SqlSmallParser.ExpressionContext)
            else:
                return self.getTypedRuleContext(SqlSmallParser.ExpressionContext,i)

        def whenBaseExpression(self, i:int=None):
            if i is None:
                return self.getTypedRuleContexts(SqlSmallParser.WhenBaseExpressionContext)
            else:
                return self.getTypedRuleContext(SqlSmallParser.WhenBaseExpressionContext,i)

        def ELSE(self):
            return self.getToken(SqlSmallParser.ELSE, 0)

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterCaseBaseExpr" ):
                listener.enterCaseBaseExpr(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitCaseBaseExpr" ):
                listener.exitCaseBaseExpr(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitCaseBaseExpr" ):
                return visitor.visitCaseBaseExpr(self)
            else:
                return visitor.visitChildren(self)



    def caseExpression(self):

        localctx = SqlSmallParser.CaseExpressionContext(self, self._ctx, self.state)
        self.enterRule(localctx, 38, self.RULE_caseExpression)
        self._la = 0 # Token type
        try:
            self.state = 338
            self._errHandler.sync(self)
            la_ = self._interp.adaptivePredict(self._input,36,self._ctx)
            if la_ == 1:
                localctx = SqlSmallParser.CaseBaseExprContext(self, localctx)
                self.enterOuterAlt(localctx, 1)
                self.state = 313
                self.match(SqlSmallParser.CASE)
                self.state = 314
                localctx.baseCaseExpr = self.expression(0)
                self.state = 316 
                self._errHandler.sync(self)
                _la = self._input.LA(1)
                while True:
                    self.state = 315
                    self.whenBaseExpression()
                    self.state = 318 
                    self._errHandler.sync(self)
                    _la = self._input.LA(1)
                    if not (_la==SqlSmallParser.WHEN):
                        break

                self.state = 322
                self._errHandler.sync(self)
                _la = self._input.LA(1)
                if _la==SqlSmallParser.ELSE:
                    self.state = 320
                    self.match(SqlSmallParser.ELSE)
                    self.state = 321
                    localctx.elseExpr = self.expression(0)


                self.state = 324
                self.match(SqlSmallParser.END)
                pass

            elif la_ == 2:
                localctx = SqlSmallParser.CaseWhenExprContext(self, localctx)
                self.enterOuterAlt(localctx, 2)
                self.state = 326
                self.match(SqlSmallParser.CASE)
                self.state = 328 
                self._errHandler.sync(self)
                _la = self._input.LA(1)
                while True:
                    self.state = 327
                    self.whenExpression()
                    self.state = 330 
                    self._errHandler.sync(self)
                    _la = self._input.LA(1)
                    if not (_la==SqlSmallParser.WHEN):
                        break

                self.state = 334
                self._errHandler.sync(self)
                _la = self._input.LA(1)
                if _la==SqlSmallParser.ELSE:
                    self.state = 332
                    self.match(SqlSmallParser.ELSE)
                    self.state = 333
                    localctx.elseExpr = self.expression(0)


                self.state = 336
                self.match(SqlSmallParser.END)
                pass


        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class NamedExpressionContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser
            self.name = None # IdentifierContext

        def expression(self):
            return self.getTypedRuleContext(SqlSmallParser.ExpressionContext,0)


        def AS(self):
            return self.getToken(SqlSmallParser.AS, 0)

        def identifier(self):
            return self.getTypedRuleContext(SqlSmallParser.IdentifierContext,0)


        def getRuleIndex(self):
            return SqlSmallParser.RULE_namedExpression

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterNamedExpression" ):
                listener.enterNamedExpression(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitNamedExpression" ):
                listener.exitNamedExpression(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitNamedExpression" ):
                return visitor.visitNamedExpression(self)
            else:
                return visitor.visitChildren(self)




    def namedExpression(self):

        localctx = SqlSmallParser.NamedExpressionContext(self, self._ctx, self.state)
        self.enterRule(localctx, 40, self.RULE_namedExpression)
        self._la = 0 # Token type
        try:
            self.enterOuterAlt(localctx, 1)
            self.state = 340
            self.expression(0)
            self.state = 343
            self._errHandler.sync(self)
            _la = self._input.LA(1)
            if _la==SqlSmallParser.AS:
                self.state = 341
                self.match(SqlSmallParser.AS)
                self.state = 342
                localctx.name = self.identifier()


        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class NamedExpressionSeqContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser

        def namedExpression(self, i:int=None):
            if i is None:
                return self.getTypedRuleContexts(SqlSmallParser.NamedExpressionContext)
            else:
                return self.getTypedRuleContext(SqlSmallParser.NamedExpressionContext,i)


        def getRuleIndex(self):
            return SqlSmallParser.RULE_namedExpressionSeq

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterNamedExpressionSeq" ):
                listener.enterNamedExpressionSeq(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitNamedExpressionSeq" ):
                listener.exitNamedExpressionSeq(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitNamedExpressionSeq" ):
                return visitor.visitNamedExpressionSeq(self)
            else:
                return visitor.visitChildren(self)




    def namedExpressionSeq(self):

        localctx = SqlSmallParser.NamedExpressionSeqContext(self, self._ctx, self.state)
        self.enterRule(localctx, 42, self.RULE_namedExpressionSeq)
        self._la = 0 # Token type
        try:
            self.enterOuterAlt(localctx, 1)
            self.state = 345
            self.namedExpression()
            self.state = 350
            self._errHandler.sync(self)
            _la = self._input.LA(1)
            while _la==SqlSmallParser.T__3:
                self.state = 346
                self.match(SqlSmallParser.T__3)
                self.state = 347
                self.namedExpression()
                self.state = 352
                self._errHandler.sync(self)
                _la = self._input.LA(1)

        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class WhenExpressionContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser
            self.baseBoolExpr = None # BooleanExpressionContext
            self.thenExpr = None # ExpressionContext

        def WHEN(self):
            return self.getToken(SqlSmallParser.WHEN, 0)

        def THEN(self):
            return self.getToken(SqlSmallParser.THEN, 0)

        def booleanExpression(self):
            return self.getTypedRuleContext(SqlSmallParser.BooleanExpressionContext,0)


        def expression(self):
            return self.getTypedRuleContext(SqlSmallParser.ExpressionContext,0)


        def getRuleIndex(self):
            return SqlSmallParser.RULE_whenExpression

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterWhenExpression" ):
                listener.enterWhenExpression(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitWhenExpression" ):
                listener.exitWhenExpression(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitWhenExpression" ):
                return visitor.visitWhenExpression(self)
            else:
                return visitor.visitChildren(self)




    def whenExpression(self):

        localctx = SqlSmallParser.WhenExpressionContext(self, self._ctx, self.state)
        self.enterRule(localctx, 44, self.RULE_whenExpression)
        try:
            self.enterOuterAlt(localctx, 1)
            self.state = 353
            self.match(SqlSmallParser.WHEN)
            self.state = 354
            localctx.baseBoolExpr = self.booleanExpression(0)
            self.state = 355
            self.match(SqlSmallParser.THEN)
            self.state = 356
            localctx.thenExpr = self.expression(0)
        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class WhenBaseExpressionContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser
            self.baseWhenExpr = None # ExpressionContext
            self.thenExpr = None # ExpressionContext

        def WHEN(self):
            return self.getToken(SqlSmallParser.WHEN, 0)

        def THEN(self):
            return self.getToken(SqlSmallParser.THEN, 0)

        def expression(self, i:int=None):
            if i is None:
                return self.getTypedRuleContexts(SqlSmallParser.ExpressionContext)
            else:
                return self.getTypedRuleContext(SqlSmallParser.ExpressionContext,i)


        def getRuleIndex(self):
            return SqlSmallParser.RULE_whenBaseExpression

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterWhenBaseExpression" ):
                listener.enterWhenBaseExpression(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitWhenBaseExpression" ):
                listener.exitWhenBaseExpression(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitWhenBaseExpression" ):
                return visitor.visitWhenBaseExpression(self)
            else:
                return visitor.visitChildren(self)




    def whenBaseExpression(self):

        localctx = SqlSmallParser.WhenBaseExpressionContext(self, self._ctx, self.state)
        self.enterRule(localctx, 46, self.RULE_whenBaseExpression)
        try:
            self.enterOuterAlt(localctx, 1)
            self.state = 358
            self.match(SqlSmallParser.WHEN)
            self.state = 359
            localctx.baseWhenExpr = self.expression(0)
            self.state = 360
            self.match(SqlSmallParser.THEN)
            self.state = 361
            localctx.thenExpr = self.expression(0)
        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class ExpressionContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser


        def getRuleIndex(self):
            return SqlSmallParser.RULE_expression

     
        def copyFrom(self, ctx:ParserRuleContext):
            super().copyFrom(ctx)


    class DayNameFuncContext(ExpressionContext):

        def __init__(self, parser, ctx:ParserRuleContext): # actually a SqlSmallParser.ExpressionContext
            super().__init__(parser)
            self.copyFrom(ctx)

        def dayNameFunction(self):
            return self.getTypedRuleContext(SqlSmallParser.DayNameFunctionContext,0)


        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterDayNameFunc" ):
                listener.enterDayNameFunc(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitDayNameFunc" ):
                listener.exitDayNameFunc(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitDayNameFunc" ):
                return visitor.visitDayNameFunc(self)
            else:
                return visitor.visitChildren(self)


    class AddContext(ExpressionContext):

        def __init__(self, parser, ctx:ParserRuleContext): # actually a SqlSmallParser.ExpressionContext
            super().__init__(parser)
            self.left = None # ExpressionContext
            self.op = None # Token
            self.right = None # ExpressionContext
            self.copyFrom(ctx)

        def expression(self, i:int=None):
            if i is None:
                return self.getTypedRuleContexts(SqlSmallParser.ExpressionContext)
            else:
                return self.getTypedRuleContext(SqlSmallParser.ExpressionContext,i)

        def PLUS(self):
            return self.getToken(SqlSmallParser.PLUS, 0)

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterAdd" ):
                listener.enterAdd(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitAdd" ):
                listener.exitAdd(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitAdd" ):
                return visitor.visitAdd(self)
            else:
                return visitor.visitChildren(self)


    class StringFuncContext(ExpressionContext):

        def __init__(self, parser, ctx:ParserRuleContext): # actually a SqlSmallParser.ExpressionContext
            super().__init__(parser)
            self.copyFrom(ctx)

        def stringFunction(self):
            return self.getTypedRuleContext(SqlSmallParser.StringFunctionContext,0)


        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterStringFunc" ):
                listener.enterStringFunc(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitStringFunc" ):
                listener.exitStringFunc(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitStringFunc" ):
                return visitor.visitStringFunc(self)
            else:
                return visitor.visitChildren(self)


    class CastExprContext(ExpressionContext):

        def __init__(self, parser, ctx:ParserRuleContext): # actually a SqlSmallParser.ExpressionContext
            super().__init__(parser)
            self.copyFrom(ctx)

        def castExpression(self):
            return self.getTypedRuleContext(SqlSmallParser.CastExpressionContext,0)


        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterCastExpr" ):
                listener.enterCastExpr(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitCastExpr" ):
                listener.exitCastExpr(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitCastExpr" ):
                return visitor.visitCastExpr(self)
            else:
                return visitor.visitChildren(self)


    class ExtractFuncContext(ExpressionContext):

        def __init__(self, parser, ctx:ParserRuleContext): # actually a SqlSmallParser.ExpressionContext
            super().__init__(parser)
            self.copyFrom(ctx)

        def extractFunction(self):
            return self.getTypedRuleContext(SqlSmallParser.ExtractFunctionContext,0)


        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterExtractFunc" ):
                listener.enterExtractFunc(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitExtractFunc" ):
                listener.exitExtractFunc(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitExtractFunc" ):
                return visitor.visitExtractFunc(self)
            else:
                return visitor.visitChildren(self)


    class SubtractContext(ExpressionContext):

        def __init__(self, parser, ctx:ParserRuleContext): # actually a SqlSmallParser.ExpressionContext
            super().__init__(parser)
            self.left = None # ExpressionContext
            self.op = None # Token
            self.right = None # ExpressionContext
            self.copyFrom(ctx)

        def expression(self, i:int=None):
            if i is None:
                return self.getTypedRuleContexts(SqlSmallParser.ExpressionContext)
            else:
                return self.getTypedRuleContext(SqlSmallParser.ExpressionContext,i)

        def MINUS(self):
            return self.getToken(SqlSmallParser.MINUS, 0)

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterSubtract" ):
                listener.enterSubtract(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitSubtract" ):
                listener.exitSubtract(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitSubtract" ):
                return visitor.visitSubtract(self)
            else:
                return visitor.visitChildren(self)


    class NestedExprContext(ExpressionContext):

        def __init__(self, parser, ctx:ParserRuleContext): # actually a SqlSmallParser.ExpressionContext
            super().__init__(parser)
            self.copyFrom(ctx)

        def expression(self):
            return self.getTypedRuleContext(SqlSmallParser.ExpressionContext,0)


        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterNestedExpr" ):
                listener.enterNestedExpr(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitNestedExpr" ):
                listener.exitNestedExpr(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitNestedExpr" ):
                return visitor.visitNestedExpr(self)
            else:
                return visitor.visitChildren(self)


    class SubqueryExprContext(ExpressionContext):

        def __init__(self, parser, ctx:ParserRuleContext): # actually a SqlSmallParser.ExpressionContext
            super().__init__(parser)
            self.copyFrom(ctx)

        def expressionSubquery(self):
            return self.getTypedRuleContext(SqlSmallParser.ExpressionSubqueryContext,0)


        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterSubqueryExpr" ):
                listener.enterSubqueryExpr(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitSubqueryExpr" ):
                listener.exitSubqueryExpr(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitSubqueryExpr" ):
                return visitor.visitSubqueryExpr(self)
            else:
                return visitor.visitChildren(self)


    class AllExprContext(ExpressionContext):

        def __init__(self, parser, ctx:ParserRuleContext): # actually a SqlSmallParser.ExpressionContext
            super().__init__(parser)
            self.copyFrom(ctx)

        def allExpression(self):
            return self.getTypedRuleContext(SqlSmallParser.AllExpressionContext,0)


        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterAllExpr" ):
                listener.enterAllExpr(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitAllExpr" ):
                listener.exitAllExpr(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitAllExpr" ):
                return visitor.visitAllExpr(self)
            else:
                return visitor.visitChildren(self)


    class FunctionExprContext(ExpressionContext):

        def __init__(self, parser, ctx:ParserRuleContext): # actually a SqlSmallParser.ExpressionContext
            super().__init__(parser)
            self.copyFrom(ctx)

        def functionExpression(self):
            return self.getTypedRuleContext(SqlSmallParser.FunctionExpressionContext,0)


        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterFunctionExpr" ):
                listener.enterFunctionExpr(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitFunctionExpr" ):
                listener.exitFunctionExpr(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitFunctionExpr" ):
                return visitor.visitFunctionExpr(self)
            else:
                return visitor.visitChildren(self)


    class RankFunctionContext(ExpressionContext):

        def __init__(self, parser, ctx:ParserRuleContext): # actually a SqlSmallParser.ExpressionContext
            super().__init__(parser)
            self.copyFrom(ctx)

        def rankingFunction(self):
            return self.getTypedRuleContext(SqlSmallParser.RankingFunctionContext,0)


        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterRankFunction" ):
                listener.enterRankFunction(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitRankFunction" ):
                listener.exitRankFunction(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitRankFunction" ):
                return visitor.visitRankFunction(self)
            else:
                return visitor.visitChildren(self)


    class CurrentTimeFuncContext(ExpressionContext):

        def __init__(self, parser, ctx:ParserRuleContext): # actually a SqlSmallParser.ExpressionContext
            super().__init__(parser)
            self.copyFrom(ctx)

        def getTime(self):
            return self.getTypedRuleContext(SqlSmallParser.GetTimeContext,0)


        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterCurrentTimeFunc" ):
                listener.enterCurrentTimeFunc(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitCurrentTimeFunc" ):
                listener.exitCurrentTimeFunc(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitCurrentTimeFunc" ):
                return visitor.visitCurrentTimeFunc(self)
            else:
                return visitor.visitChildren(self)


    class LiteralExprContext(ExpressionContext):

        def __init__(self, parser, ctx:ParserRuleContext): # actually a SqlSmallParser.ExpressionContext
            super().__init__(parser)
            self.copyFrom(ctx)

        def literal(self):
            return self.getTypedRuleContext(SqlSmallParser.LiteralContext,0)


        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterLiteralExpr" ):
                listener.enterLiteralExpr(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitLiteralExpr" ):
                listener.exitLiteralExpr(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitLiteralExpr" ):
                return visitor.visitLiteralExpr(self)
            else:
                return visitor.visitChildren(self)


    class DivideContext(ExpressionContext):

        def __init__(self, parser, ctx:ParserRuleContext): # actually a SqlSmallParser.ExpressionContext
            super().__init__(parser)
            self.left = None # ExpressionContext
            self.op = None # Token
            self.right = None # ExpressionContext
            self.copyFrom(ctx)

        def expression(self, i:int=None):
            if i is None:
                return self.getTypedRuleContexts(SqlSmallParser.ExpressionContext)
            else:
                return self.getTypedRuleContext(SqlSmallParser.ExpressionContext,i)

        def SLASH(self):
            return self.getToken(SqlSmallParser.SLASH, 0)

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterDivide" ):
                listener.enterDivide(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitDivide" ):
                listener.exitDivide(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitDivide" ):
                return visitor.visitDivide(self)
            else:
                return visitor.visitChildren(self)


    class CaseExprContext(ExpressionContext):

        def __init__(self, parser, ctx:ParserRuleContext): # actually a SqlSmallParser.ExpressionContext
            super().__init__(parser)
            self.copyFrom(ctx)

        def caseExpression(self):
            return self.getTypedRuleContext(SqlSmallParser.CaseExpressionContext,0)


        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterCaseExpr" ):
                listener.enterCaseExpr(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitCaseExpr" ):
                listener.exitCaseExpr(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitCaseExpr" ):
                return visitor.visitCaseExpr(self)
            else:
                return visitor.visitChildren(self)


    class MultiplyContext(ExpressionContext):

        def __init__(self, parser, ctx:ParserRuleContext): # actually a SqlSmallParser.ExpressionContext
            super().__init__(parser)
            self.left = None # ExpressionContext
            self.op = None # Token
            self.right = None # ExpressionContext
            self.copyFrom(ctx)

        def expression(self, i:int=None):
            if i is None:
                return self.getTypedRuleContexts(SqlSmallParser.ExpressionContext)
            else:
                return self.getTypedRuleContext(SqlSmallParser.ExpressionContext,i)

        def ASTERISK(self):
            return self.getToken(SqlSmallParser.ASTERISK, 0)

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterMultiply" ):
                listener.enterMultiply(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitMultiply" ):
                listener.exitMultiply(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitMultiply" ):
                return visitor.visitMultiply(self)
            else:
                return visitor.visitChildren(self)


    class ModuloContext(ExpressionContext):

        def __init__(self, parser, ctx:ParserRuleContext): # actually a SqlSmallParser.ExpressionContext
            super().__init__(parser)
            self.left = None # ExpressionContext
            self.op = None # Token
            self.right = None # ExpressionContext
            self.copyFrom(ctx)

        def expression(self, i:int=None):
            if i is None:
                return self.getTypedRuleContexts(SqlSmallParser.ExpressionContext)
            else:
                return self.getTypedRuleContext(SqlSmallParser.ExpressionContext,i)

        def PERCENT(self):
            return self.getToken(SqlSmallParser.PERCENT, 0)

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterModulo" ):
                listener.enterModulo(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitModulo" ):
                listener.exitModulo(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitModulo" ):
                return visitor.visitModulo(self)
            else:
                return visitor.visitChildren(self)


    class ColumnNameContext(ExpressionContext):

        def __init__(self, parser, ctx:ParserRuleContext): # actually a SqlSmallParser.ExpressionContext
            super().__init__(parser)
            self.name = None # QualifiedColumnNameContext
            self.copyFrom(ctx)

        def qualifiedColumnName(self):
            return self.getTypedRuleContext(SqlSmallParser.QualifiedColumnNameContext,0)


        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterColumnName" ):
                listener.enterColumnName(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitColumnName" ):
                listener.exitColumnName(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitColumnName" ):
                return visitor.visitColumnName(self)
            else:
                return visitor.visitChildren(self)



    def expression(self, _p:int=0):
        _parentctx = self._ctx
        _parentState = self.state
        localctx = SqlSmallParser.ExpressionContext(self, self._ctx, _parentState)
        _prevctx = localctx
        _startState = 48
        self.enterRecursionRule(localctx, 48, self.RULE_expression, _p)
        try:
            self.enterOuterAlt(localctx, 1)
            self.state = 380
            self._errHandler.sync(self)
            la_ = self._interp.adaptivePredict(self._input,39,self._ctx)
            if la_ == 1:
                localctx = SqlSmallParser.ColumnNameContext(self, localctx)
                self._ctx = localctx
                _prevctx = localctx

                self.state = 364
                localctx.name = self.qualifiedColumnName()
                pass

            elif la_ == 2:
                localctx = SqlSmallParser.CaseExprContext(self, localctx)
                self._ctx = localctx
                _prevctx = localctx
                self.state = 365
                self.caseExpression()
                pass

            elif la_ == 3:
                localctx = SqlSmallParser.CastExprContext(self, localctx)
                self._ctx = localctx
                _prevctx = localctx
                self.state = 366
                self.castExpression()
                pass

            elif la_ == 4:
                localctx = SqlSmallParser.AllExprContext(self, localctx)
                self._ctx = localctx
                _prevctx = localctx
                self.state = 367
                self.allExpression()
                pass

            elif la_ == 5:
                localctx = SqlSmallParser.LiteralExprContext(self, localctx)
                self._ctx = localctx
                _prevctx = localctx
                self.state = 368
                self.literal()
                pass

            elif la_ == 6:
                localctx = SqlSmallParser.RankFunctionContext(self, localctx)
                self._ctx = localctx
                _prevctx = localctx
                self.state = 369
                self.rankingFunction()
                pass

            elif la_ == 7:
                localctx = SqlSmallParser.FunctionExprContext(self, localctx)
                self._ctx = localctx
                _prevctx = localctx
                self.state = 370
                self.functionExpression()
                pass

            elif la_ == 8:
                localctx = SqlSmallParser.SubqueryExprContext(self, localctx)
                self._ctx = localctx
                _prevctx = localctx
                self.state = 371
                self.expressionSubquery()
                pass

            elif la_ == 9:
                localctx = SqlSmallParser.NestedExprContext(self, localctx)
                self._ctx = localctx
                _prevctx = localctx
                self.state = 372
                self.match(SqlSmallParser.T__1)
                self.state = 373
                self.expression(0)
                self.state = 374
                self.match(SqlSmallParser.T__2)
                pass

            elif la_ == 10:
                localctx = SqlSmallParser.StringFuncContext(self, localctx)
                self._ctx = localctx
                _prevctx = localctx
                self.state = 376
                self.stringFunction()
                pass

            elif la_ == 11:
                localctx = SqlSmallParser.CurrentTimeFuncContext(self, localctx)
                self._ctx = localctx
                _prevctx = localctx
                self.state = 377
                self.getTime()
                pass

            elif la_ == 12:
                localctx = SqlSmallParser.ExtractFuncContext(self, localctx)
                self._ctx = localctx
                _prevctx = localctx
                self.state = 378
                self.extractFunction()
                pass

            elif la_ == 13:
                localctx = SqlSmallParser.DayNameFuncContext(self, localctx)
                self._ctx = localctx
                _prevctx = localctx
                self.state = 379
                self.dayNameFunction()
                pass


            self._ctx.stop = self._input.LT(-1)
            self.state = 399
            self._errHandler.sync(self)
            _alt = self._interp.adaptivePredict(self._input,41,self._ctx)
            while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER:
                if _alt==1:
                    if self._parseListeners is not None:
                        self.triggerExitRuleEvent()
                    _prevctx = localctx
                    self.state = 397
                    self._errHandler.sync(self)
                    la_ = self._interp.adaptivePredict(self._input,40,self._ctx)
                    if la_ == 1:
                        localctx = SqlSmallParser.MultiplyContext(self, SqlSmallParser.ExpressionContext(self, _parentctx, _parentState))
                        localctx.left = _prevctx
                        self.pushNewRecursionContext(localctx, _startState, self.RULE_expression)
                        self.state = 382
                        if not self.precpred(self._ctx, 17):
                            from antlr4.error.Errors import FailedPredicateException
                            raise FailedPredicateException(self, "self.precpred(self._ctx, 17)")
                        self.state = 383
                        localctx.op = self.match(SqlSmallParser.ASTERISK)
                        self.state = 384
                        localctx.right = self.expression(18)
                        pass

                    elif la_ == 2:
                        localctx = SqlSmallParser.DivideContext(self, SqlSmallParser.ExpressionContext(self, _parentctx, _parentState))
                        localctx.left = _prevctx
                        self.pushNewRecursionContext(localctx, _startState, self.RULE_expression)
                        self.state = 385
                        if not self.precpred(self._ctx, 16):
                            from antlr4.error.Errors import FailedPredicateException
                            raise FailedPredicateException(self, "self.precpred(self._ctx, 16)")
                        self.state = 386
                        localctx.op = self.match(SqlSmallParser.SLASH)
                        self.state = 387
                        localctx.right = self.expression(17)
                        pass

                    elif la_ == 3:
                        localctx = SqlSmallParser.ModuloContext(self, SqlSmallParser.ExpressionContext(self, _parentctx, _parentState))
                        localctx.left = _prevctx
                        self.pushNewRecursionContext(localctx, _startState, self.RULE_expression)
                        self.state = 388
                        if not self.precpred(self._ctx, 15):
                            from antlr4.error.Errors import FailedPredicateException
                            raise FailedPredicateException(self, "self.precpred(self._ctx, 15)")
                        self.state = 389
                        localctx.op = self.match(SqlSmallParser.PERCENT)
                        self.state = 390
                        localctx.right = self.expression(16)
                        pass

                    elif la_ == 4:
                        localctx = SqlSmallParser.AddContext(self, SqlSmallParser.ExpressionContext(self, _parentctx, _parentState))
                        localctx.left = _prevctx
                        self.pushNewRecursionContext(localctx, _startState, self.RULE_expression)
                        self.state = 391
                        if not self.precpred(self._ctx, 14):
                            from antlr4.error.Errors import FailedPredicateException
                            raise FailedPredicateException(self, "self.precpred(self._ctx, 14)")
                        self.state = 392
                        localctx.op = self.match(SqlSmallParser.PLUS)
                        self.state = 393
                        localctx.right = self.expression(15)
                        pass

                    elif la_ == 5:
                        localctx = SqlSmallParser.SubtractContext(self, SqlSmallParser.ExpressionContext(self, _parentctx, _parentState))
                        localctx.left = _prevctx
                        self.pushNewRecursionContext(localctx, _startState, self.RULE_expression)
                        self.state = 394
                        if not self.precpred(self._ctx, 13):
                            from antlr4.error.Errors import FailedPredicateException
                            raise FailedPredicateException(self, "self.precpred(self._ctx, 13)")
                        self.state = 395
                        localctx.op = self.match(SqlSmallParser.MINUS)
                        self.state = 396
                        localctx.right = self.expression(14)
                        pass

             
                self.state = 401
                self._errHandler.sync(self)
                _alt = self._interp.adaptivePredict(self._input,41,self._ctx)

        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.unrollRecursionContexts(_parentctx)
        return localctx


    class PredicateContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser


        def getRuleIndex(self):
            return SqlSmallParser.RULE_predicate

     
        def copyFrom(self, ctx:ParserRuleContext):
            super().copyFrom(ctx)



    class InConditionContext(PredicateContext):

        def __init__(self, parser, ctx:ParserRuleContext): # actually a SqlSmallParser.PredicateContext
            super().__init__(parser)
            self.kind = None # Token
            self.copyFrom(ctx)

        def expression(self, i:int=None):
            if i is None:
                return self.getTypedRuleContexts(SqlSmallParser.ExpressionContext)
            else:
                return self.getTypedRuleContext(SqlSmallParser.ExpressionContext,i)

        def IN(self):
            return self.getToken(SqlSmallParser.IN, 0)
        def NOT(self):
            return self.getToken(SqlSmallParser.NOT, 0)

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterInCondition" ):
                listener.enterInCondition(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitInCondition" ):
                listener.exitInCondition(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitInCondition" ):
                return visitor.visitInCondition(self)
            else:
                return visitor.visitChildren(self)


    class IsConditionContext(PredicateContext):

        def __init__(self, parser, ctx:ParserRuleContext): # actually a SqlSmallParser.PredicateContext
            super().__init__(parser)
            self.kind = None # Token
            self.copyFrom(ctx)

        def IS(self):
            return self.getToken(SqlSmallParser.IS, 0)
        def NULL(self):
            return self.getToken(SqlSmallParser.NULL, 0)
        def TRUE(self):
            return self.getToken(SqlSmallParser.TRUE, 0)
        def FALSE(self):
            return self.getToken(SqlSmallParser.FALSE, 0)
        def NOT(self):
            return self.getToken(SqlSmallParser.NOT, 0)

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterIsCondition" ):
                listener.enterIsCondition(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitIsCondition" ):
                listener.exitIsCondition(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitIsCondition" ):
                return visitor.visitIsCondition(self)
            else:
                return visitor.visitChildren(self)


    class BetweenConditionContext(PredicateContext):

        def __init__(self, parser, ctx:ParserRuleContext): # actually a SqlSmallParser.PredicateContext
            super().__init__(parser)
            self.kind = None # Token
            self.lower = None # ExpressionContext
            self.upper = None # ExpressionContext
            self.copyFrom(ctx)

        def AND(self):
            return self.getToken(SqlSmallParser.AND, 0)
        def BETWEEN(self):
            return self.getToken(SqlSmallParser.BETWEEN, 0)
        def expression(self, i:int=None):
            if i is None:
                return self.getTypedRuleContexts(SqlSmallParser.ExpressionContext)
            else:
                return self.getTypedRuleContext(SqlSmallParser.ExpressionContext,i)

        def NOT(self):
            return self.getToken(SqlSmallParser.NOT, 0)

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterBetweenCondition" ):
                listener.enterBetweenCondition(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitBetweenCondition" ):
                listener.exitBetweenCondition(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitBetweenCondition" ):
                return visitor.visitBetweenCondition(self)
            else:
                return visitor.visitChildren(self)



    def predicate(self):

        localctx = SqlSmallParser.PredicateContext(self, self._ctx, self.state)
        self.enterRule(localctx, 50, self.RULE_predicate)
        self._la = 0 # Token type
        try:
            self.state = 430
            self._errHandler.sync(self)
            la_ = self._interp.adaptivePredict(self._input,46,self._ctx)
            if la_ == 1:
                localctx = SqlSmallParser.BetweenConditionContext(self, localctx)
                self.enterOuterAlt(localctx, 1)
                self.state = 403
                self._errHandler.sync(self)
                _la = self._input.LA(1)
                if _la==SqlSmallParser.NOT:
                    self.state = 402
                    self.match(SqlSmallParser.NOT)


                self.state = 405
                localctx.kind = self.match(SqlSmallParser.BETWEEN)
                self.state = 406
                localctx.lower = self.expression(0)
                self.state = 407
                self.match(SqlSmallParser.AND)
                self.state = 408
                localctx.upper = self.expression(0)
                pass

            elif la_ == 2:
                localctx = SqlSmallParser.InConditionContext(self, localctx)
                self.enterOuterAlt(localctx, 2)
                self.state = 411
                self._errHandler.sync(self)
                _la = self._input.LA(1)
                if _la==SqlSmallParser.NOT:
                    self.state = 410
                    self.match(SqlSmallParser.NOT)


                self.state = 413
                localctx.kind = self.match(SqlSmallParser.IN)
                self.state = 414
                self.match(SqlSmallParser.T__1)
                self.state = 415
                self.expression(0)
                self.state = 420
                self._errHandler.sync(self)
                _la = self._input.LA(1)
                while _la==SqlSmallParser.T__3:
                    self.state = 416
                    self.match(SqlSmallParser.T__3)
                    self.state = 417
                    self.expression(0)
                    self.state = 422
                    self._errHandler.sync(self)
                    _la = self._input.LA(1)

                self.state = 423
                self.match(SqlSmallParser.T__2)
                pass

            elif la_ == 3:
                localctx = SqlSmallParser.IsConditionContext(self, localctx)
                self.enterOuterAlt(localctx, 3)
                self.state = 425
                self.match(SqlSmallParser.IS)
                self.state = 427
                self._errHandler.sync(self)
                _la = self._input.LA(1)
                if _la==SqlSmallParser.NOT:
                    self.state = 426
                    self.match(SqlSmallParser.NOT)


                self.state = 429
                localctx.kind = self._input.LT(1)
                _la = self._input.LA(1)
                if not(_la==SqlSmallParser.FALSE or _la==SqlSmallParser.NULL or _la==SqlSmallParser.TRUE):
                    localctx.kind = self._errHandler.recoverInline(self)
                else:
                    self._errHandler.reportMatch(self)
                    self.consume()
                pass


        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class FunctionExpressionContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser


        def getRuleIndex(self):
            return SqlSmallParser.RULE_functionExpression

     
        def copyFrom(self, ctx:ParserRuleContext):
            super().copyFrom(ctx)



    class IifFuncContext(FunctionExpressionContext):

        def __init__(self, parser, ctx:ParserRuleContext): # actually a SqlSmallParser.FunctionExpressionContext
            super().__init__(parser)
            self.test = None # BooleanExpressionContext
            self.yes = None # ExpressionContext
            self.no = None # ExpressionContext
            self.copyFrom(ctx)

        def IIF(self):
            return self.getToken(SqlSmallParser.IIF, 0)
        def booleanExpression(self):
            return self.getTypedRuleContext(SqlSmallParser.BooleanExpressionContext,0)

        def expression(self, i:int=None):
            if i is None:
                return self.getTypedRuleContexts(SqlSmallParser.ExpressionContext)
            else:
                return self.getTypedRuleContext(SqlSmallParser.ExpressionContext,i)


        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterIifFunc" ):
                listener.enterIifFunc(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitIifFunc" ):
                listener.exitIifFunc(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitIifFunc" ):
                return visitor.visitIifFunc(self)
            else:
                return visitor.visitChildren(self)


    class PowerFuncContext(FunctionExpressionContext):

        def __init__(self, parser, ctx:ParserRuleContext): # actually a SqlSmallParser.FunctionExpressionContext
            super().__init__(parser)
            self.copyFrom(ctx)

        def powerFunction(self):
            return self.getTypedRuleContext(SqlSmallParser.PowerFunctionContext,0)


        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterPowerFunc" ):
                listener.enterPowerFunc(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitPowerFunc" ):
                listener.exitPowerFunc(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitPowerFunc" ):
                return visitor.visitPowerFunc(self)
            else:
                return visitor.visitChildren(self)


    class ChooseFuncContext(FunctionExpressionContext):

        def __init__(self, parser, ctx:ParserRuleContext): # actually a SqlSmallParser.FunctionExpressionContext
            super().__init__(parser)
            self.index = None # ExpressionContext
            self.copyFrom(ctx)

        def CHOOSE(self):
            return self.getToken(SqlSmallParser.CHOOSE, 0)
        def expression(self):
            return self.getTypedRuleContext(SqlSmallParser.ExpressionContext,0)

        def literal(self, i:int=None):
            if i is None:
                return self.getTypedRuleContexts(SqlSmallParser.LiteralContext)
            else:
                return self.getTypedRuleContext(SqlSmallParser.LiteralContext,i)


        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterChooseFunc" ):
                listener.enterChooseFunc(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitChooseFunc" ):
                listener.exitChooseFunc(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitChooseFunc" ):
                return visitor.visitChooseFunc(self)
            else:
                return visitor.visitChildren(self)


    class MathFuncContext(FunctionExpressionContext):

        def __init__(self, parser, ctx:ParserRuleContext): # actually a SqlSmallParser.FunctionExpressionContext
            super().__init__(parser)
            self.function = None # MathFunctionNameContext
            self.copyFrom(ctx)

        def expression(self):
            return self.getTypedRuleContext(SqlSmallParser.ExpressionContext,0)

        def mathFunctionName(self):
            return self.getTypedRuleContext(SqlSmallParser.MathFunctionNameContext,0)


        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterMathFunc" ):
                listener.enterMathFunc(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitMathFunc" ):
                listener.exitMathFunc(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitMathFunc" ):
                return visitor.visitMathFunc(self)
            else:
                return visitor.visitChildren(self)


    class AggFuncContext(FunctionExpressionContext):

        def __init__(self, parser, ctx:ParserRuleContext): # actually a SqlSmallParser.FunctionExpressionContext
            super().__init__(parser)
            self.function = None # AggregateFunctionNameContext
            self.copyFrom(ctx)

        def expression(self):
            return self.getTypedRuleContext(SqlSmallParser.ExpressionContext,0)

        def aggregateFunctionName(self):
            return self.getTypedRuleContext(SqlSmallParser.AggregateFunctionNameContext,0)

        def setQuantifier(self):
            return self.getTypedRuleContext(SqlSmallParser.SetQuantifierContext,0)


        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterAggFunc" ):
                listener.enterAggFunc(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitAggFunc" ):
                listener.exitAggFunc(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitAggFunc" ):
                return visitor.visitAggFunc(self)
            else:
                return visitor.visitChildren(self)


    class TruncFuncContext(FunctionExpressionContext):

        def __init__(self, parser, ctx:ParserRuleContext): # actually a SqlSmallParser.FunctionExpressionContext
            super().__init__(parser)
            self.copyFrom(ctx)

        def truncFunction(self):
            return self.getTypedRuleContext(SqlSmallParser.TruncFunctionContext,0)


        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterTruncFunc" ):
                listener.enterTruncFunc(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitTruncFunc" ):
                listener.exitTruncFunc(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitTruncFunc" ):
                return visitor.visitTruncFunc(self)
            else:
                return visitor.visitChildren(self)


    class BareFuncContext(FunctionExpressionContext):

        def __init__(self, parser, ctx:ParserRuleContext): # actually a SqlSmallParser.FunctionExpressionContext
            super().__init__(parser)
            self.copyFrom(ctx)

        def bareFunction(self):
            return self.getTypedRuleContext(SqlSmallParser.BareFunctionContext,0)


        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterBareFunc" ):
                listener.enterBareFunc(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitBareFunc" ):
                listener.exitBareFunc(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitBareFunc" ):
                return visitor.visitBareFunc(self)
            else:
                return visitor.visitChildren(self)


    class RoundFuncContext(FunctionExpressionContext):

        def __init__(self, parser, ctx:ParserRuleContext): # actually a SqlSmallParser.FunctionExpressionContext
            super().__init__(parser)
            self.copyFrom(ctx)

        def roundFunction(self):
            return self.getTypedRuleContext(SqlSmallParser.RoundFunctionContext,0)


        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterRoundFunc" ):
                listener.enterRoundFunc(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitRoundFunc" ):
                listener.exitRoundFunc(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitRoundFunc" ):
                return visitor.visitRoundFunc(self)
            else:
                return visitor.visitChildren(self)



    def functionExpression(self):

        localctx = SqlSmallParser.FunctionExpressionContext(self, self._ctx, self.state)
        self.enterRule(localctx, 52, self.RULE_functionExpression)
        self._la = 0 # Token type
        try:
            self.state = 469
            self._errHandler.sync(self)
            token = self._input.LA(1)
            if token in [SqlSmallParser.NEWID, SqlSmallParser.PI, SqlSmallParser.RAND, SqlSmallParser.RANDOM]:
                localctx = SqlSmallParser.BareFuncContext(self, localctx)
                self.enterOuterAlt(localctx, 1)
                self.state = 432
                self.bareFunction()
                pass
            elif token in [SqlSmallParser.ROUND]:
                localctx = SqlSmallParser.RoundFuncContext(self, localctx)
                self.enterOuterAlt(localctx, 2)
                self.state = 433
                self.roundFunction()
                pass
            elif token in [SqlSmallParser.POWER]:
                localctx = SqlSmallParser.PowerFuncContext(self, localctx)
                self.enterOuterAlt(localctx, 3)
                self.state = 434
                self.powerFunction()
                pass
            elif token in [SqlSmallParser.TRUNC, SqlSmallParser.TRUNCATE]:
                localctx = SqlSmallParser.TruncFuncContext(self, localctx)
                self.enterOuterAlt(localctx, 4)
                self.state = 435
                self.truncFunction()
                pass
            elif token in [SqlSmallParser.AVG, SqlSmallParser.COUNT, SqlSmallParser.MAX, SqlSmallParser.MIN, SqlSmallParser.PERCENTILE_CONT, SqlSmallParser.PERCENTILE_DISC, SqlSmallParser.STD, SqlSmallParser.STDDEV, SqlSmallParser.STDEV, SqlSmallParser.SUM, SqlSmallParser.VAR, SqlSmallParser.VARIANCE]:
                localctx = SqlSmallParser.AggFuncContext(self, localctx)
                self.enterOuterAlt(localctx, 5)
                self.state = 436
                localctx.function = self.aggregateFunctionName()
                self.state = 437
                self.match(SqlSmallParser.T__1)
                self.state = 439
                self._errHandler.sync(self)
                _la = self._input.LA(1)
                if _la==SqlSmallParser.ALL or _la==SqlSmallParser.DISTINCT or _la==SqlSmallParser.TOP:
                    self.state = 438
                    self.setQuantifier()


                self.state = 441
                self.expression(0)
                self.state = 442
                self.match(SqlSmallParser.T__2)
                pass
            elif token in [SqlSmallParser.ABS, SqlSmallParser.ACOS, SqlSmallParser.ASIN, SqlSmallParser.ATAN, SqlSmallParser.ATANH, SqlSmallParser.CEIL, SqlSmallParser.CEILING, SqlSmallParser.COS, SqlSmallParser.DEGREES, SqlSmallParser.EXP, SqlSmallParser.FLOOR, SqlSmallParser.LN, SqlSmallParser.LOG, SqlSmallParser.LOG10, SqlSmallParser.LOG2, SqlSmallParser.SIGN, SqlSmallParser.SIN, SqlSmallParser.SQRT, SqlSmallParser.SQUARE, SqlSmallParser.TAN]:
                localctx = SqlSmallParser.MathFuncContext(self, localctx)
                self.enterOuterAlt(localctx, 6)
                self.state = 444
                localctx.function = self.mathFunctionName()
                self.state = 445
                self.match(SqlSmallParser.T__1)
                self.state = 446
                self.expression(0)
                self.state = 447
                self.match(SqlSmallParser.T__2)
                pass
            elif token in [SqlSmallParser.IIF]:
                localctx = SqlSmallParser.IifFuncContext(self, localctx)
                self.enterOuterAlt(localctx, 7)
                self.state = 449
                self.match(SqlSmallParser.IIF)
                self.state = 450
                self.match(SqlSmallParser.T__1)
                self.state = 451
                localctx.test = self.booleanExpression(0)
                self.state = 452
                self.match(SqlSmallParser.T__3)
                self.state = 453
                localctx.yes = self.expression(0)
                self.state = 454
                self.match(SqlSmallParser.T__3)
                self.state = 455
                localctx.no = self.expression(0)
                self.state = 456
                self.match(SqlSmallParser.T__2)
                pass
            elif token in [SqlSmallParser.CHOOSE]:
                localctx = SqlSmallParser.ChooseFuncContext(self, localctx)
                self.enterOuterAlt(localctx, 8)
                self.state = 458
                self.match(SqlSmallParser.CHOOSE)
                self.state = 459
                self.match(SqlSmallParser.T__1)
                self.state = 460
                localctx.index = self.expression(0)
                self.state = 463 
                self._errHandler.sync(self)
                _la = self._input.LA(1)
                while True:
                    self.state = 461
                    self.match(SqlSmallParser.T__3)
                    self.state = 462
                    self.literal()
                    self.state = 465 
                    self._errHandler.sync(self)
                    _la = self._input.LA(1)
                    if not (_la==SqlSmallParser.T__3):
                        break

                self.state = 467
                self.match(SqlSmallParser.T__2)
                pass
            else:
                raise NoViableAltException(self)

        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class BooleanExpressionContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser


        def getRuleIndex(self):
            return SqlSmallParser.RULE_booleanExpression

     
        def copyFrom(self, ctx:ParserRuleContext):
            super().copyFrom(ctx)


    class BoolColumnContext(BooleanExpressionContext):

        def __init__(self, parser, ctx:ParserRuleContext): # actually a SqlSmallParser.BooleanExpressionContext
            super().__init__(parser)
            self.name = None # QualifiedColumnNameContext
            self.copyFrom(ctx)

        def qualifiedColumnName(self):
            return self.getTypedRuleContext(SqlSmallParser.QualifiedColumnNameContext,0)


        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterBoolColumn" ):
                listener.enterBoolColumn(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitBoolColumn" ):
                listener.exitBoolColumn(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitBoolColumn" ):
                return visitor.visitBoolColumn(self)
            else:
                return visitor.visitChildren(self)


    class LogicalNotContext(BooleanExpressionContext):

        def __init__(self, parser, ctx:ParserRuleContext): # actually a SqlSmallParser.BooleanExpressionContext
            super().__init__(parser)
            self.copyFrom(ctx)

        def NOT(self):
            return self.getToken(SqlSmallParser.NOT, 0)
        def booleanExpression(self):
            return self.getTypedRuleContext(SqlSmallParser.BooleanExpressionContext,0)


        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterLogicalNot" ):
                listener.enterLogicalNot(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitLogicalNot" ):
                listener.exitLogicalNot(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitLogicalNot" ):
                return visitor.visitLogicalNot(self)
            else:
                return visitor.visitChildren(self)


    class ComparisonContext(BooleanExpressionContext):

        def __init__(self, parser, ctx:ParserRuleContext): # actually a SqlSmallParser.BooleanExpressionContext
            super().__init__(parser)
            self.left = None # ExpressionContext
            self.op = None # ComparisonOperatorContext
            self.right = None # ExpressionContext
            self.copyFrom(ctx)

        def expression(self, i:int=None):
            if i is None:
                return self.getTypedRuleContexts(SqlSmallParser.ExpressionContext)
            else:
                return self.getTypedRuleContext(SqlSmallParser.ExpressionContext,i)

        def comparisonOperator(self):
            return self.getTypedRuleContext(SqlSmallParser.ComparisonOperatorContext,0)


        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterComparison" ):
                listener.enterComparison(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitComparison" ):
                listener.exitComparison(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitComparison" ):
                return visitor.visitComparison(self)
            else:
                return visitor.visitChildren(self)


    class PredicatedContext(BooleanExpressionContext):

        def __init__(self, parser, ctx:ParserRuleContext): # actually a SqlSmallParser.BooleanExpressionContext
            super().__init__(parser)
            self.copyFrom(ctx)

        def expression(self):
            return self.getTypedRuleContext(SqlSmallParser.ExpressionContext,0)

        def predicate(self):
            return self.getTypedRuleContext(SqlSmallParser.PredicateContext,0)


        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterPredicated" ):
                listener.enterPredicated(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitPredicated" ):
                listener.exitPredicated(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitPredicated" ):
                return visitor.visitPredicated(self)
            else:
                return visitor.visitChildren(self)


    class ConjunctionContext(BooleanExpressionContext):

        def __init__(self, parser, ctx:ParserRuleContext): # actually a SqlSmallParser.BooleanExpressionContext
            super().__init__(parser)
            self.left = None # BooleanExpressionContext
            self.right = None # BooleanExpressionContext
            self.copyFrom(ctx)

        def AND(self):
            return self.getToken(SqlSmallParser.AND, 0)
        def booleanExpression(self, i:int=None):
            if i is None:
                return self.getTypedRuleContexts(SqlSmallParser.BooleanExpressionContext)
            else:
                return self.getTypedRuleContext(SqlSmallParser.BooleanExpressionContext,i)


        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterConjunction" ):
                listener.enterConjunction(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitConjunction" ):
                listener.exitConjunction(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitConjunction" ):
                return visitor.visitConjunction(self)
            else:
                return visitor.visitChildren(self)


    class DisjunctionContext(BooleanExpressionContext):

        def __init__(self, parser, ctx:ParserRuleContext): # actually a SqlSmallParser.BooleanExpressionContext
            super().__init__(parser)
            self.left = None # BooleanExpressionContext
            self.right = None # BooleanExpressionContext
            self.copyFrom(ctx)

        def OR(self):
            return self.getToken(SqlSmallParser.OR, 0)
        def booleanExpression(self, i:int=None):
            if i is None:
                return self.getTypedRuleContexts(SqlSmallParser.BooleanExpressionContext)
            else:
                return self.getTypedRuleContext(SqlSmallParser.BooleanExpressionContext,i)


        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterDisjunction" ):
                listener.enterDisjunction(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitDisjunction" ):
                listener.exitDisjunction(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitDisjunction" ):
                return visitor.visitDisjunction(self)
            else:
                return visitor.visitChildren(self)


    class NestedBooleanContext(BooleanExpressionContext):

        def __init__(self, parser, ctx:ParserRuleContext): # actually a SqlSmallParser.BooleanExpressionContext
            super().__init__(parser)
            self.copyFrom(ctx)

        def booleanExpression(self):
            return self.getTypedRuleContext(SqlSmallParser.BooleanExpressionContext,0)


        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterNestedBoolean" ):
                listener.enterNestedBoolean(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitNestedBoolean" ):
                listener.exitNestedBoolean(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitNestedBoolean" ):
                return visitor.visitNestedBoolean(self)
            else:
                return visitor.visitChildren(self)



    def booleanExpression(self, _p:int=0):
        _parentctx = self._ctx
        _parentState = self.state
        localctx = SqlSmallParser.BooleanExpressionContext(self, self._ctx, _parentState)
        _prevctx = localctx
        _startState = 54
        self.enterRecursionRule(localctx, 54, self.RULE_booleanExpression, _p)
        try:
            self.enterOuterAlt(localctx, 1)
            self.state = 486
            self._errHandler.sync(self)
            la_ = self._interp.adaptivePredict(self._input,50,self._ctx)
            if la_ == 1:
                localctx = SqlSmallParser.LogicalNotContext(self, localctx)
                self._ctx = localctx
                _prevctx = localctx

                self.state = 472
                self.match(SqlSmallParser.NOT)
                self.state = 473
                self.booleanExpression(7)
                pass

            elif la_ == 2:
                localctx = SqlSmallParser.ComparisonContext(self, localctx)
                self._ctx = localctx
                _prevctx = localctx
                self.state = 474
                localctx.left = self.expression(0)
                self.state = 475
                localctx.op = self.comparisonOperator()
                self.state = 476
                localctx.right = self.expression(0)
                pass

            elif la_ == 3:
                localctx = SqlSmallParser.NestedBooleanContext(self, localctx)
                self._ctx = localctx
                _prevctx = localctx
                self.state = 478
                self.match(SqlSmallParser.T__1)
                self.state = 479
                self.booleanExpression(0)
                self.state = 480
                self.match(SqlSmallParser.T__2)
                pass

            elif la_ == 4:
                localctx = SqlSmallParser.PredicatedContext(self, localctx)
                self._ctx = localctx
                _prevctx = localctx
                self.state = 482
                self.expression(0)
                self.state = 483
                self.predicate()
                pass

            elif la_ == 5:
                localctx = SqlSmallParser.BoolColumnContext(self, localctx)
                self._ctx = localctx
                _prevctx = localctx
                self.state = 485
                localctx.name = self.qualifiedColumnName()
                pass


            self._ctx.stop = self._input.LT(-1)
            self.state = 496
            self._errHandler.sync(self)
            _alt = self._interp.adaptivePredict(self._input,52,self._ctx)
            while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER:
                if _alt==1:
                    if self._parseListeners is not None:
                        self.triggerExitRuleEvent()
                    _prevctx = localctx
                    self.state = 494
                    self._errHandler.sync(self)
                    la_ = self._interp.adaptivePredict(self._input,51,self._ctx)
                    if la_ == 1:
                        localctx = SqlSmallParser.ConjunctionContext(self, SqlSmallParser.BooleanExpressionContext(self, _parentctx, _parentState))
                        localctx.left = _prevctx
                        self.pushNewRecursionContext(localctx, _startState, self.RULE_booleanExpression)
                        self.state = 488
                        if not self.precpred(self._ctx, 5):
                            from antlr4.error.Errors import FailedPredicateException
                            raise FailedPredicateException(self, "self.precpred(self._ctx, 5)")
                        self.state = 489
                        self.match(SqlSmallParser.AND)
                        self.state = 490
                        localctx.right = self.booleanExpression(6)
                        pass

                    elif la_ == 2:
                        localctx = SqlSmallParser.DisjunctionContext(self, SqlSmallParser.BooleanExpressionContext(self, _parentctx, _parentState))
                        localctx.left = _prevctx
                        self.pushNewRecursionContext(localctx, _startState, self.RULE_booleanExpression)
                        self.state = 491
                        if not self.precpred(self._ctx, 4):
                            from antlr4.error.Errors import FailedPredicateException
                            raise FailedPredicateException(self, "self.precpred(self._ctx, 4)")
                        self.state = 492
                        self.match(SqlSmallParser.OR)
                        self.state = 493
                        localctx.right = self.booleanExpression(5)
                        pass

             
                self.state = 498
                self._errHandler.sync(self)
                _alt = self._interp.adaptivePredict(self._input,52,self._ctx)

        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.unrollRecursionContexts(_parentctx)
        return localctx


    class CastExpressionContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser
            self.fromExpr = None # ExpressionContext

        def CAST(self):
            return self.getToken(SqlSmallParser.CAST, 0)

        def AS(self):
            return self.getToken(SqlSmallParser.AS, 0)

        def dbType(self):
            return self.getTypedRuleContext(SqlSmallParser.DbTypeContext,0)


        def expression(self):
            return self.getTypedRuleContext(SqlSmallParser.ExpressionContext,0)


        def getRuleIndex(self):
            return SqlSmallParser.RULE_castExpression

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterCastExpression" ):
                listener.enterCastExpression(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitCastExpression" ):
                listener.exitCastExpression(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitCastExpression" ):
                return visitor.visitCastExpression(self)
            else:
                return visitor.visitChildren(self)




    def castExpression(self):

        localctx = SqlSmallParser.CastExpressionContext(self, self._ctx, self.state)
        self.enterRule(localctx, 56, self.RULE_castExpression)
        try:
            self.enterOuterAlt(localctx, 1)
            self.state = 499
            self.match(SqlSmallParser.CAST)
            self.state = 500
            self.match(SqlSmallParser.T__1)
            self.state = 501
            localctx.fromExpr = self.expression(0)
            self.state = 502
            self.match(SqlSmallParser.AS)
            self.state = 503
            self.dbType()
            self.state = 504
            self.match(SqlSmallParser.T__2)
        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class DbTypeContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser

        def INTEGER(self):
            return self.getToken(SqlSmallParser.INTEGER, 0)

        def FLOAT(self):
            return self.getToken(SqlSmallParser.FLOAT, 0)

        def BOOLEAN(self):
            return self.getToken(SqlSmallParser.BOOLEAN, 0)

        def TIMESTAMP(self):
            return self.getToken(SqlSmallParser.TIMESTAMP, 0)

        def DATE(self):
            return self.getToken(SqlSmallParser.DATE, 0)

        def TIME(self):
            return self.getToken(SqlSmallParser.TIME, 0)

        def variableString(self):
            return self.getTypedRuleContext(SqlSmallParser.VariableStringContext,0)


        def fixedString(self):
            return self.getTypedRuleContext(SqlSmallParser.FixedStringContext,0)


        def getRuleIndex(self):
            return SqlSmallParser.RULE_dbType

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterDbType" ):
                listener.enterDbType(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitDbType" ):
                listener.exitDbType(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitDbType" ):
                return visitor.visitDbType(self)
            else:
                return visitor.visitChildren(self)




    def dbType(self):

        localctx = SqlSmallParser.DbTypeContext(self, self._ctx, self.state)
        self.enterRule(localctx, 58, self.RULE_dbType)
        try:
            self.state = 514
            self._errHandler.sync(self)
            token = self._input.LA(1)
            if token in [SqlSmallParser.INTEGER]:
                self.enterOuterAlt(localctx, 1)
                self.state = 506
                self.match(SqlSmallParser.INTEGER)
                pass
            elif token in [SqlSmallParser.FLOAT]:
                self.enterOuterAlt(localctx, 2)
                self.state = 507
                self.match(SqlSmallParser.FLOAT)
                pass
            elif token in [SqlSmallParser.BOOLEAN]:
                self.enterOuterAlt(localctx, 3)
                self.state = 508
                self.match(SqlSmallParser.BOOLEAN)
                pass
            elif token in [SqlSmallParser.TIMESTAMP]:
                self.enterOuterAlt(localctx, 4)
                self.state = 509
                self.match(SqlSmallParser.TIMESTAMP)
                pass
            elif token in [SqlSmallParser.DATE]:
                self.enterOuterAlt(localctx, 5)
                self.state = 510
                self.match(SqlSmallParser.DATE)
                pass
            elif token in [SqlSmallParser.TIME]:
                self.enterOuterAlt(localctx, 6)
                self.state = 511
                self.match(SqlSmallParser.TIME)
                pass
            elif token in [SqlSmallParser.VARCHAR, SqlSmallParser.NVARCHAR]:
                self.enterOuterAlt(localctx, 7)
                self.state = 512
                self.variableString()
                pass
            elif token in [SqlSmallParser.CHAR, SqlSmallParser.NCHAR]:
                self.enterOuterAlt(localctx, 8)
                self.state = 513
                self.fixedString()
                pass
            else:
                raise NoViableAltException(self)

        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class VariableStringContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser
            self.varCharLength = None # Token

        def VARCHAR(self):
            return self.getToken(SqlSmallParser.VARCHAR, 0)

        def NVARCHAR(self):
            return self.getToken(SqlSmallParser.NVARCHAR, 0)

        def MAX(self):
            return self.getToken(SqlSmallParser.MAX, 0)

        def INTEGER_VALUE(self):
            return self.getToken(SqlSmallParser.INTEGER_VALUE, 0)

        def getRuleIndex(self):
            return SqlSmallParser.RULE_variableString

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterVariableString" ):
                listener.enterVariableString(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitVariableString" ):
                listener.exitVariableString(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitVariableString" ):
                return visitor.visitVariableString(self)
            else:
                return visitor.visitChildren(self)




    def variableString(self):

        localctx = SqlSmallParser.VariableStringContext(self, self._ctx, self.state)
        self.enterRule(localctx, 60, self.RULE_variableString)
        self._la = 0 # Token type
        try:
            self.enterOuterAlt(localctx, 1)
            self.state = 516
            _la = self._input.LA(1)
            if not(_la==SqlSmallParser.VARCHAR or _la==SqlSmallParser.NVARCHAR):
                self._errHandler.recoverInline(self)
            else:
                self._errHandler.reportMatch(self)
                self.consume()
            self.state = 521
            self._errHandler.sync(self)
            token = self._input.LA(1)
            if token in [SqlSmallParser.T__1]:
                self.state = 517
                self.match(SqlSmallParser.T__1)
                self.state = 518
                localctx.varCharLength = self.match(SqlSmallParser.INTEGER_VALUE)
                pass
            elif token in [SqlSmallParser.MAX]:
                self.state = 519
                self.match(SqlSmallParser.MAX)
                self.state = 520
                self.match(SqlSmallParser.T__2)
                pass
            elif token in [SqlSmallParser.T__2]:
                pass
            else:
                pass
        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class FixedStringContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser
            self.fixedCharLength = None # Token

        def CHAR(self):
            return self.getToken(SqlSmallParser.CHAR, 0)

        def NCHAR(self):
            return self.getToken(SqlSmallParser.NCHAR, 0)

        def INTEGER_VALUE(self):
            return self.getToken(SqlSmallParser.INTEGER_VALUE, 0)

        def getRuleIndex(self):
            return SqlSmallParser.RULE_fixedString

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterFixedString" ):
                listener.enterFixedString(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitFixedString" ):
                listener.exitFixedString(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitFixedString" ):
                return visitor.visitFixedString(self)
            else:
                return visitor.visitChildren(self)




    def fixedString(self):

        localctx = SqlSmallParser.FixedStringContext(self, self._ctx, self.state)
        self.enterRule(localctx, 62, self.RULE_fixedString)
        self._la = 0 # Token type
        try:
            self.enterOuterAlt(localctx, 1)
            self.state = 523
            _la = self._input.LA(1)
            if not(_la==SqlSmallParser.CHAR or _la==SqlSmallParser.NCHAR):
                self._errHandler.recoverInline(self)
            else:
                self._errHandler.reportMatch(self)
                self.consume()
            self.state = 527
            self._errHandler.sync(self)
            _la = self._input.LA(1)
            if _la==SqlSmallParser.T__1:
                self.state = 524
                self.match(SqlSmallParser.T__1)
                self.state = 525
                localctx.fixedCharLength = self.match(SqlSmallParser.INTEGER_VALUE)
                self.state = 526
                self.match(SqlSmallParser.T__2)


        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class BareFunctionContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser
            self.function = None # BareFunctionNameContext

        def bareFunctionName(self):
            return self.getTypedRuleContext(SqlSmallParser.BareFunctionNameContext,0)


        def getRuleIndex(self):
            return SqlSmallParser.RULE_bareFunction

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterBareFunction" ):
                listener.enterBareFunction(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitBareFunction" ):
                listener.exitBareFunction(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitBareFunction" ):
                return visitor.visitBareFunction(self)
            else:
                return visitor.visitChildren(self)




    def bareFunction(self):

        localctx = SqlSmallParser.BareFunctionContext(self, self._ctx, self.state)
        self.enterRule(localctx, 64, self.RULE_bareFunction)
        try:
            self.enterOuterAlt(localctx, 1)
            self.state = 529
            localctx.function = self.bareFunctionName()
            self.state = 530
            self.match(SqlSmallParser.T__1)
            self.state = 531
            self.match(SqlSmallParser.T__2)
        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class RankingFunctionContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser
            self.function = None # RankingFunctionNameContext

        def overClause(self):
            return self.getTypedRuleContext(SqlSmallParser.OverClauseContext,0)


        def rankingFunctionName(self):
            return self.getTypedRuleContext(SqlSmallParser.RankingFunctionNameContext,0)


        def getRuleIndex(self):
            return SqlSmallParser.RULE_rankingFunction

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterRankingFunction" ):
                listener.enterRankingFunction(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitRankingFunction" ):
                listener.exitRankingFunction(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitRankingFunction" ):
                return visitor.visitRankingFunction(self)
            else:
                return visitor.visitChildren(self)




    def rankingFunction(self):

        localctx = SqlSmallParser.RankingFunctionContext(self, self._ctx, self.state)
        self.enterRule(localctx, 66, self.RULE_rankingFunction)
        try:
            self.enterOuterAlt(localctx, 1)
            self.state = 533
            localctx.function = self.rankingFunctionName()
            self.state = 534
            self.match(SqlSmallParser.T__1)
            self.state = 535
            self.match(SqlSmallParser.T__2)
            self.state = 536
            self.overClause()
        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class ComparisonOperatorContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser

        def EQ(self):
            return self.getToken(SqlSmallParser.EQ, 0)

        def NEQ(self):
            return self.getToken(SqlSmallParser.NEQ, 0)

        def NEQJ(self):
            return self.getToken(SqlSmallParser.NEQJ, 0)

        def LT(self):
            return self.getToken(SqlSmallParser.LT, 0)

        def LTE(self):
            return self.getToken(SqlSmallParser.LTE, 0)

        def GT(self):
            return self.getToken(SqlSmallParser.GT, 0)

        def GTE(self):
            return self.getToken(SqlSmallParser.GTE, 0)

        def NSEQ(self):
            return self.getToken(SqlSmallParser.NSEQ, 0)

        def getRuleIndex(self):
            return SqlSmallParser.RULE_comparisonOperator

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterComparisonOperator" ):
                listener.enterComparisonOperator(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitComparisonOperator" ):
                listener.exitComparisonOperator(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitComparisonOperator" ):
                return visitor.visitComparisonOperator(self)
            else:
                return visitor.visitChildren(self)




    def comparisonOperator(self):

        localctx = SqlSmallParser.ComparisonOperatorContext(self, self._ctx, self.state)
        self.enterRule(localctx, 68, self.RULE_comparisonOperator)
        self._la = 0 # Token type
        try:
            self.enterOuterAlt(localctx, 1)
            self.state = 538
            _la = self._input.LA(1)
            if not(((((_la - 136)) & ~0x3f) == 0 and ((1 << (_la - 136)) & ((1 << (SqlSmallParser.EQ - 136)) | (1 << (SqlSmallParser.NSEQ - 136)) | (1 << (SqlSmallParser.NEQ - 136)) | (1 << (SqlSmallParser.NEQJ - 136)) | (1 << (SqlSmallParser.LT - 136)) | (1 << (SqlSmallParser.LTE - 136)) | (1 << (SqlSmallParser.GT - 136)) | (1 << (SqlSmallParser.GTE - 136)))) != 0)):
                self._errHandler.recoverInline(self)
            else:
                self._errHandler.reportMatch(self)
                self.consume()
        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class BooleanValueContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser

        def TRUE(self):
            return self.getToken(SqlSmallParser.TRUE, 0)

        def FALSE(self):
            return self.getToken(SqlSmallParser.FALSE, 0)

        def getRuleIndex(self):
            return SqlSmallParser.RULE_booleanValue

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterBooleanValue" ):
                listener.enterBooleanValue(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitBooleanValue" ):
                listener.exitBooleanValue(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitBooleanValue" ):
                return visitor.visitBooleanValue(self)
            else:
                return visitor.visitChildren(self)




    def booleanValue(self):

        localctx = SqlSmallParser.BooleanValueContext(self, self._ctx, self.state)
        self.enterRule(localctx, 70, self.RULE_booleanValue)
        self._la = 0 # Token type
        try:
            self.enterOuterAlt(localctx, 1)
            self.state = 540
            _la = self._input.LA(1)
            if not(_la==SqlSmallParser.FALSE or _la==SqlSmallParser.TRUE):
                self._errHandler.recoverInline(self)
            else:
                self._errHandler.reportMatch(self)
                self.consume()
        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class AllExpressionContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser

        def ASTERISK(self):
            return self.getToken(SqlSmallParser.ASTERISK, 0)

        def identifier(self):
            return self.getTypedRuleContext(SqlSmallParser.IdentifierContext,0)


        def getRuleIndex(self):
            return SqlSmallParser.RULE_allExpression

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterAllExpression" ):
                listener.enterAllExpression(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitAllExpression" ):
                listener.exitAllExpression(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitAllExpression" ):
                return visitor.visitAllExpression(self)
            else:
                return visitor.visitChildren(self)




    def allExpression(self):

        localctx = SqlSmallParser.AllExpressionContext(self, self._ctx, self.state)
        self.enterRule(localctx, 72, self.RULE_allExpression)
        try:
            self.state = 547
            self._errHandler.sync(self)
            token = self._input.LA(1)
            if token in [SqlSmallParser.ASTERISK]:
                self.enterOuterAlt(localctx, 1)
                self.state = 542
                self.match(SqlSmallParser.ASTERISK)
                pass
            elif token in [SqlSmallParser.IDENT]:
                self.enterOuterAlt(localctx, 2)
                self.state = 543
                self.identifier()
                self.state = 544
                self.match(SqlSmallParser.T__4)
                self.state = 545
                self.match(SqlSmallParser.ASTERISK)
                pass
            else:
                raise NoViableAltException(self)

        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class LiteralContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser


        def getRuleIndex(self):
            return SqlSmallParser.RULE_literal

     
        def copyFrom(self, ctx:ParserRuleContext):
            super().copyFrom(ctx)



    class NullLiteralContext(LiteralContext):

        def __init__(self, parser, ctx:ParserRuleContext): # actually a SqlSmallParser.LiteralContext
            super().__init__(parser)
            self.copyFrom(ctx)

        def NULL(self):
            return self.getToken(SqlSmallParser.NULL, 0)

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterNullLiteral" ):
                listener.enterNullLiteral(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitNullLiteral" ):
                listener.exitNullLiteral(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitNullLiteral" ):
                return visitor.visitNullLiteral(self)
            else:
                return visitor.visitChildren(self)


    class FalseLiteralContext(LiteralContext):

        def __init__(self, parser, ctx:ParserRuleContext): # actually a SqlSmallParser.LiteralContext
            super().__init__(parser)
            self.copyFrom(ctx)

        def FALSE(self):
            return self.getToken(SqlSmallParser.FALSE, 0)

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterFalseLiteral" ):
                listener.enterFalseLiteral(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitFalseLiteral" ):
                listener.exitFalseLiteral(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitFalseLiteral" ):
                return visitor.visitFalseLiteral(self)
            else:
                return visitor.visitChildren(self)


    class StringLiteralContext(LiteralContext):

        def __init__(self, parser, ctx:ParserRuleContext): # actually a SqlSmallParser.LiteralContext
            super().__init__(parser)
            self.copyFrom(ctx)

        def STRING(self):
            return self.getToken(SqlSmallParser.STRING, 0)

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterStringLiteral" ):
                listener.enterStringLiteral(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitStringLiteral" ):
                listener.exitStringLiteral(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitStringLiteral" ):
                return visitor.visitStringLiteral(self)
            else:
                return visitor.visitChildren(self)


    class TrueLiteralContext(LiteralContext):

        def __init__(self, parser, ctx:ParserRuleContext): # actually a SqlSmallParser.LiteralContext
            super().__init__(parser)
            self.copyFrom(ctx)

        def TRUE(self):
            return self.getToken(SqlSmallParser.TRUE, 0)

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterTrueLiteral" ):
                listener.enterTrueLiteral(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitTrueLiteral" ):
                listener.exitTrueLiteral(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitTrueLiteral" ):
                return visitor.visitTrueLiteral(self)
            else:
                return visitor.visitChildren(self)


    class NumberLiteralContext(LiteralContext):

        def __init__(self, parser, ctx:ParserRuleContext): # actually a SqlSmallParser.LiteralContext
            super().__init__(parser)
            self.copyFrom(ctx)

        def number(self):
            return self.getTypedRuleContext(SqlSmallParser.NumberContext,0)


        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterNumberLiteral" ):
                listener.enterNumberLiteral(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitNumberLiteral" ):
                listener.exitNumberLiteral(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitNumberLiteral" ):
                return visitor.visitNumberLiteral(self)
            else:
                return visitor.visitChildren(self)



    def literal(self):

        localctx = SqlSmallParser.LiteralContext(self, self._ctx, self.state)
        self.enterRule(localctx, 74, self.RULE_literal)
        try:
            self.state = 554
            self._errHandler.sync(self)
            token = self._input.LA(1)
            if token in [SqlSmallParser.STRING]:
                localctx = SqlSmallParser.StringLiteralContext(self, localctx)
                self.enterOuterAlt(localctx, 1)
                self.state = 549
                self.match(SqlSmallParser.STRING)
                pass
            elif token in [SqlSmallParser.MINUS, SqlSmallParser.INTEGER_VALUE, SqlSmallParser.DECIMAL_VALUE]:
                localctx = SqlSmallParser.NumberLiteralContext(self, localctx)
                self.enterOuterAlt(localctx, 2)
                self.state = 550
                self.number()
                pass
            elif token in [SqlSmallParser.TRUE]:
                localctx = SqlSmallParser.TrueLiteralContext(self, localctx)
                self.enterOuterAlt(localctx, 3)
                self.state = 551
                self.match(SqlSmallParser.TRUE)
                pass
            elif token in [SqlSmallParser.FALSE]:
                localctx = SqlSmallParser.FalseLiteralContext(self, localctx)
                self.enterOuterAlt(localctx, 4)
                self.state = 552
                self.match(SqlSmallParser.FALSE)
                pass
            elif token in [SqlSmallParser.NULL]:
                localctx = SqlSmallParser.NullLiteralContext(self, localctx)
                self.enterOuterAlt(localctx, 5)
                self.state = 553
                self.match(SqlSmallParser.NULL)
                pass
            else:
                raise NoViableAltException(self)

        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class ExtractFunctionContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser
            self.sourceExpr = None # ExpressionContext

        def EXTRACT(self):
            return self.getToken(SqlSmallParser.EXTRACT, 0)

        def datePart(self):
            return self.getTypedRuleContext(SqlSmallParser.DatePartContext,0)


        def FROM(self):
            return self.getToken(SqlSmallParser.FROM, 0)

        def expression(self):
            return self.getTypedRuleContext(SqlSmallParser.ExpressionContext,0)


        def getRuleIndex(self):
            return SqlSmallParser.RULE_extractFunction

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterExtractFunction" ):
                listener.enterExtractFunction(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitExtractFunction" ):
                listener.exitExtractFunction(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitExtractFunction" ):
                return visitor.visitExtractFunction(self)
            else:
                return visitor.visitChildren(self)




    def extractFunction(self):

        localctx = SqlSmallParser.ExtractFunctionContext(self, self._ctx, self.state)
        self.enterRule(localctx, 76, self.RULE_extractFunction)
        try:
            self.enterOuterAlt(localctx, 1)
            self.state = 556
            self.match(SqlSmallParser.EXTRACT)
            self.state = 557
            self.match(SqlSmallParser.T__1)
            self.state = 558
            self.datePart()
            self.state = 559
            self.match(SqlSmallParser.FROM)
            self.state = 560
            localctx.sourceExpr = self.expression(0)
            self.state = 561
            self.match(SqlSmallParser.T__2)
        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class DayNameFunctionContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser
            self.expr = None # ExpressionContext

        def DAYNAME(self):
            return self.getToken(SqlSmallParser.DAYNAME, 0)

        def expression(self):
            return self.getTypedRuleContext(SqlSmallParser.ExpressionContext,0)


        def getRuleIndex(self):
            return SqlSmallParser.RULE_dayNameFunction

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterDayNameFunction" ):
                listener.enterDayNameFunction(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitDayNameFunction" ):
                listener.exitDayNameFunction(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitDayNameFunction" ):
                return visitor.visitDayNameFunction(self)
            else:
                return visitor.visitChildren(self)




    def dayNameFunction(self):

        localctx = SqlSmallParser.DayNameFunctionContext(self, self._ctx, self.state)
        self.enterRule(localctx, 78, self.RULE_dayNameFunction)
        try:
            self.enterOuterAlt(localctx, 1)
            self.state = 563
            self.match(SqlSmallParser.DAYNAME)
            self.state = 564
            self.match(SqlSmallParser.T__1)
            self.state = 565
            localctx.expr = self.expression(0)
            self.state = 566
            self.match(SqlSmallParser.T__2)
        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class DatePartContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser

        def YEAR(self):
            return self.getToken(SqlSmallParser.YEAR, 0)

        def MONTH(self):
            return self.getToken(SqlSmallParser.MONTH, 0)

        def DAY(self):
            return self.getToken(SqlSmallParser.DAY, 0)

        def HOUR(self):
            return self.getToken(SqlSmallParser.HOUR, 0)

        def MINUTE(self):
            return self.getToken(SqlSmallParser.MINUTE, 0)

        def SECOND(self):
            return self.getToken(SqlSmallParser.SECOND, 0)

        def MICROSECOND(self):
            return self.getToken(SqlSmallParser.MICROSECOND, 0)

        def WEEKDAY(self):
            return self.getToken(SqlSmallParser.WEEKDAY, 0)

        def getRuleIndex(self):
            return SqlSmallParser.RULE_datePart

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterDatePart" ):
                listener.enterDatePart(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitDatePart" ):
                listener.exitDatePart(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitDatePart" ):
                return visitor.visitDatePart(self)
            else:
                return visitor.visitChildren(self)




    def datePart(self):

        localctx = SqlSmallParser.DatePartContext(self, self._ctx, self.state)
        self.enterRule(localctx, 80, self.RULE_datePart)
        self._la = 0 # Token type
        try:
            self.enterOuterAlt(localctx, 1)
            self.state = 568
            _la = self._input.LA(1)
            if not(_la==SqlSmallParser.DAY or _la==SqlSmallParser.HOUR or ((((_la - 74)) & ~0x3f) == 0 and ((1 << (_la - 74)) & ((1 << (SqlSmallParser.MICROSECOND - 74)) | (1 << (SqlSmallParser.MINUTE - 74)) | (1 << (SqlSmallParser.MONTH - 74)) | (1 << (SqlSmallParser.SECOND - 74)) | (1 << (SqlSmallParser.WEEKDAY - 74)) | (1 << (SqlSmallParser.YEAR - 74)))) != 0)):
                self._errHandler.recoverInline(self)
            else:
                self._errHandler.reportMatch(self)
                self.consume()
        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class GetTimeContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser

        def CURRENT_DATE(self):
            return self.getToken(SqlSmallParser.CURRENT_DATE, 0)

        def CURRENT_TIME(self):
            return self.getToken(SqlSmallParser.CURRENT_TIME, 0)

        def CURRENT_TIMESTAMP(self):
            return self.getToken(SqlSmallParser.CURRENT_TIMESTAMP, 0)

        def getRuleIndex(self):
            return SqlSmallParser.RULE_getTime

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterGetTime" ):
                listener.enterGetTime(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitGetTime" ):
                listener.exitGetTime(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitGetTime" ):
                return visitor.visitGetTime(self)
            else:
                return visitor.visitChildren(self)




    def getTime(self):

        localctx = SqlSmallParser.GetTimeContext(self, self._ctx, self.state)
        self.enterRule(localctx, 82, self.RULE_getTime)
        self._la = 0 # Token type
        try:
            self.enterOuterAlt(localctx, 1)
            self.state = 570
            _la = self._input.LA(1)
            if not((((_la) & ~0x3f) == 0 and ((1 << _la) & ((1 << SqlSmallParser.CURRENT_DATE) | (1 << SqlSmallParser.CURRENT_TIME) | (1 << SqlSmallParser.CURRENT_TIMESTAMP))) != 0)):
                self._errHandler.recoverInline(self)
            else:
                self._errHandler.reportMatch(self)
                self.consume()
        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class StringFunctionContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser

        def stringUpper(self):
            return self.getTypedRuleContext(SqlSmallParser.StringUpperContext,0)


        def stringLower(self):
            return self.getTypedRuleContext(SqlSmallParser.StringLowerContext,0)


        def stringConcat(self):
            return self.getTypedRuleContext(SqlSmallParser.StringConcatContext,0)


        def coalesceFunction(self):
            return self.getTypedRuleContext(SqlSmallParser.CoalesceFunctionContext,0)


        def trimFunction(self):
            return self.getTypedRuleContext(SqlSmallParser.TrimFunctionContext,0)


        def substringFunction(self):
            return self.getTypedRuleContext(SqlSmallParser.SubstringFunctionContext,0)


        def positionFunction(self):
            return self.getTypedRuleContext(SqlSmallParser.PositionFunctionContext,0)


        def charLengthFunction(self):
            return self.getTypedRuleContext(SqlSmallParser.CharLengthFunctionContext,0)


        def getRuleIndex(self):
            return SqlSmallParser.RULE_stringFunction

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterStringFunction" ):
                listener.enterStringFunction(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitStringFunction" ):
                listener.exitStringFunction(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitStringFunction" ):
                return visitor.visitStringFunction(self)
            else:
                return visitor.visitChildren(self)




    def stringFunction(self):

        localctx = SqlSmallParser.StringFunctionContext(self, self._ctx, self.state)
        self.enterRule(localctx, 84, self.RULE_stringFunction)
        try:
            self.state = 580
            self._errHandler.sync(self)
            token = self._input.LA(1)
            if token in [SqlSmallParser.UPPER]:
                self.enterOuterAlt(localctx, 1)
                self.state = 572
                self.stringUpper()
                pass
            elif token in [SqlSmallParser.LOWER]:
                self.enterOuterAlt(localctx, 2)
                self.state = 573
                self.stringLower()
                pass
            elif token in [SqlSmallParser.CONCAT]:
                self.enterOuterAlt(localctx, 3)
                self.state = 574
                self.stringConcat()
                pass
            elif token in [SqlSmallParser.COALESCE]:
                self.enterOuterAlt(localctx, 4)
                self.state = 575
                self.coalesceFunction()
                pass
            elif token in [SqlSmallParser.TRIM]:
                self.enterOuterAlt(localctx, 5)
                self.state = 576
                self.trimFunction()
                pass
            elif token in [SqlSmallParser.SUBSTRING]:
                self.enterOuterAlt(localctx, 6)
                self.state = 577
                self.substringFunction()
                pass
            elif token in [SqlSmallParser.POSITION]:
                self.enterOuterAlt(localctx, 7)
                self.state = 578
                self.positionFunction()
                pass
            elif token in [SqlSmallParser.CHAR_LENGTH]:
                self.enterOuterAlt(localctx, 8)
                self.state = 579
                self.charLengthFunction()
                pass
            else:
                raise NoViableAltException(self)

        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class StringUpperContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser
            self.sourceExpr = None # ExpressionContext

        def UPPER(self):
            return self.getToken(SqlSmallParser.UPPER, 0)

        def expression(self):
            return self.getTypedRuleContext(SqlSmallParser.ExpressionContext,0)


        def getRuleIndex(self):
            return SqlSmallParser.RULE_stringUpper

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterStringUpper" ):
                listener.enterStringUpper(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitStringUpper" ):
                listener.exitStringUpper(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitStringUpper" ):
                return visitor.visitStringUpper(self)
            else:
                return visitor.visitChildren(self)




    def stringUpper(self):

        localctx = SqlSmallParser.StringUpperContext(self, self._ctx, self.state)
        self.enterRule(localctx, 86, self.RULE_stringUpper)
        try:
            self.enterOuterAlt(localctx, 1)
            self.state = 582
            self.match(SqlSmallParser.UPPER)
            self.state = 583
            self.match(SqlSmallParser.T__1)
            self.state = 584
            localctx.sourceExpr = self.expression(0)
            self.state = 585
            self.match(SqlSmallParser.T__2)
        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class StringLowerContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser
            self.sourceExpr = None # ExpressionContext

        def LOWER(self):
            return self.getToken(SqlSmallParser.LOWER, 0)

        def expression(self):
            return self.getTypedRuleContext(SqlSmallParser.ExpressionContext,0)


        def getRuleIndex(self):
            return SqlSmallParser.RULE_stringLower

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterStringLower" ):
                listener.enterStringLower(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitStringLower" ):
                listener.exitStringLower(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitStringLower" ):
                return visitor.visitStringLower(self)
            else:
                return visitor.visitChildren(self)




    def stringLower(self):

        localctx = SqlSmallParser.StringLowerContext(self, self._ctx, self.state)
        self.enterRule(localctx, 88, self.RULE_stringLower)
        try:
            self.enterOuterAlt(localctx, 1)
            self.state = 587
            self.match(SqlSmallParser.LOWER)
            self.state = 588
            self.match(SqlSmallParser.T__1)
            self.state = 589
            localctx.sourceExpr = self.expression(0)
            self.state = 590
            self.match(SqlSmallParser.T__2)
        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class StringConcatContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser

        def CONCAT(self):
            return self.getToken(SqlSmallParser.CONCAT, 0)

        def expression(self, i:int=None):
            if i is None:
                return self.getTypedRuleContexts(SqlSmallParser.ExpressionContext)
            else:
                return self.getTypedRuleContext(SqlSmallParser.ExpressionContext,i)


        def getRuleIndex(self):
            return SqlSmallParser.RULE_stringConcat

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterStringConcat" ):
                listener.enterStringConcat(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitStringConcat" ):
                listener.exitStringConcat(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitStringConcat" ):
                return visitor.visitStringConcat(self)
            else:
                return visitor.visitChildren(self)




    def stringConcat(self):

        localctx = SqlSmallParser.StringConcatContext(self, self._ctx, self.state)
        self.enterRule(localctx, 90, self.RULE_stringConcat)
        self._la = 0 # Token type
        try:
            self.enterOuterAlt(localctx, 1)
            self.state = 592
            self.match(SqlSmallParser.CONCAT)
            self.state = 593
            self.match(SqlSmallParser.T__1)
            self.state = 594
            self.expression(0)
            self.state = 599
            self._errHandler.sync(self)
            _la = self._input.LA(1)
            while _la==SqlSmallParser.T__3:
                self.state = 595
                self.match(SqlSmallParser.T__3)
                self.state = 596
                self.expression(0)
                self.state = 601
                self._errHandler.sync(self)
                _la = self._input.LA(1)

            self.state = 602
            self.match(SqlSmallParser.T__2)
        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class CoalesceFunctionContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser

        def COALESCE(self):
            return self.getToken(SqlSmallParser.COALESCE, 0)

        def expression(self, i:int=None):
            if i is None:
                return self.getTypedRuleContexts(SqlSmallParser.ExpressionContext)
            else:
                return self.getTypedRuleContext(SqlSmallParser.ExpressionContext,i)


        def getRuleIndex(self):
            return SqlSmallParser.RULE_coalesceFunction

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterCoalesceFunction" ):
                listener.enterCoalesceFunction(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitCoalesceFunction" ):
                listener.exitCoalesceFunction(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitCoalesceFunction" ):
                return visitor.visitCoalesceFunction(self)
            else:
                return visitor.visitChildren(self)




    def coalesceFunction(self):

        localctx = SqlSmallParser.CoalesceFunctionContext(self, self._ctx, self.state)
        self.enterRule(localctx, 92, self.RULE_coalesceFunction)
        self._la = 0 # Token type
        try:
            self.enterOuterAlt(localctx, 1)
            self.state = 604
            self.match(SqlSmallParser.COALESCE)
            self.state = 605
            self.match(SqlSmallParser.T__1)
            self.state = 606
            self.expression(0)
            self.state = 611
            self._errHandler.sync(self)
            _la = self._input.LA(1)
            while _la==SqlSmallParser.T__3:
                self.state = 607
                self.match(SqlSmallParser.T__3)
                self.state = 608
                self.expression(0)
                self.state = 613
                self._errHandler.sync(self)
                _la = self._input.LA(1)

            self.state = 614
            self.match(SqlSmallParser.T__2)
        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class TrimFunctionContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser
            self.sourceExpr = None # ExpressionContext

        def TRIM(self):
            return self.getToken(SqlSmallParser.TRIM, 0)

        def expression(self):
            return self.getTypedRuleContext(SqlSmallParser.ExpressionContext,0)


        def getRuleIndex(self):
            return SqlSmallParser.RULE_trimFunction

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterTrimFunction" ):
                listener.enterTrimFunction(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitTrimFunction" ):
                listener.exitTrimFunction(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitTrimFunction" ):
                return visitor.visitTrimFunction(self)
            else:
                return visitor.visitChildren(self)




    def trimFunction(self):

        localctx = SqlSmallParser.TrimFunctionContext(self, self._ctx, self.state)
        self.enterRule(localctx, 94, self.RULE_trimFunction)
        try:
            self.enterOuterAlt(localctx, 1)
            self.state = 616
            self.match(SqlSmallParser.TRIM)
            self.state = 617
            self.match(SqlSmallParser.T__1)
            self.state = 618
            localctx.sourceExpr = self.expression(0)
            self.state = 619
            self.match(SqlSmallParser.T__2)
        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class SubstringFunctionContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser
            self.sourceExpr = None # ExpressionContext
            self.startIdx = None # ExpressionContext
            self.length = None # ExpressionContext

        def SUBSTRING(self):
            return self.getToken(SqlSmallParser.SUBSTRING, 0)

        def FROM(self):
            return self.getToken(SqlSmallParser.FROM, 0)

        def expression(self, i:int=None):
            if i is None:
                return self.getTypedRuleContexts(SqlSmallParser.ExpressionContext)
            else:
                return self.getTypedRuleContext(SqlSmallParser.ExpressionContext,i)


        def FOR(self):
            return self.getToken(SqlSmallParser.FOR, 0)

        def getRuleIndex(self):
            return SqlSmallParser.RULE_substringFunction

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterSubstringFunction" ):
                listener.enterSubstringFunction(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitSubstringFunction" ):
                listener.exitSubstringFunction(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitSubstringFunction" ):
                return visitor.visitSubstringFunction(self)
            else:
                return visitor.visitChildren(self)




    def substringFunction(self):

        localctx = SqlSmallParser.SubstringFunctionContext(self, self._ctx, self.state)
        self.enterRule(localctx, 96, self.RULE_substringFunction)
        self._la = 0 # Token type
        try:
            self.enterOuterAlt(localctx, 1)
            self.state = 621
            self.match(SqlSmallParser.SUBSTRING)
            self.state = 622
            self.match(SqlSmallParser.T__1)
            self.state = 623
            localctx.sourceExpr = self.expression(0)
            self.state = 624
            self.match(SqlSmallParser.FROM)
            self.state = 625
            localctx.startIdx = self.expression(0)
            self.state = 628
            self._errHandler.sync(self)
            _la = self._input.LA(1)
            if _la==SqlSmallParser.FOR:
                self.state = 626
                self.match(SqlSmallParser.FOR)
                self.state = 627
                localctx.length = self.expression(0)


            self.state = 630
            self.match(SqlSmallParser.T__2)
        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class PositionFunctionContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser
            self.searchString = None # ExpressionContext
            self.sourceString = None # ExpressionContext

        def POSITION(self):
            return self.getToken(SqlSmallParser.POSITION, 0)

        def IN(self):
            return self.getToken(SqlSmallParser.IN, 0)

        def expression(self, i:int=None):
            if i is None:
                return self.getTypedRuleContexts(SqlSmallParser.ExpressionContext)
            else:
                return self.getTypedRuleContext(SqlSmallParser.ExpressionContext,i)


        def getRuleIndex(self):
            return SqlSmallParser.RULE_positionFunction

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterPositionFunction" ):
                listener.enterPositionFunction(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitPositionFunction" ):
                listener.exitPositionFunction(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitPositionFunction" ):
                return visitor.visitPositionFunction(self)
            else:
                return visitor.visitChildren(self)




    def positionFunction(self):

        localctx = SqlSmallParser.PositionFunctionContext(self, self._ctx, self.state)
        self.enterRule(localctx, 98, self.RULE_positionFunction)
        try:
            self.enterOuterAlt(localctx, 1)
            self.state = 632
            self.match(SqlSmallParser.POSITION)
            self.state = 633
            self.match(SqlSmallParser.T__1)
            self.state = 634
            localctx.searchString = self.expression(0)
            self.state = 635
            self.match(SqlSmallParser.IN)
            self.state = 636
            localctx.sourceString = self.expression(0)
            self.state = 637
            self.match(SqlSmallParser.T__2)
        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class CharLengthFunctionContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser
            self.sourceString = None # ExpressionContext

        def CHAR_LENGTH(self):
            return self.getToken(SqlSmallParser.CHAR_LENGTH, 0)

        def expression(self):
            return self.getTypedRuleContext(SqlSmallParser.ExpressionContext,0)


        def getRuleIndex(self):
            return SqlSmallParser.RULE_charLengthFunction

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterCharLengthFunction" ):
                listener.enterCharLengthFunction(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitCharLengthFunction" ):
                listener.exitCharLengthFunction(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitCharLengthFunction" ):
                return visitor.visitCharLengthFunction(self)
            else:
                return visitor.visitChildren(self)




    def charLengthFunction(self):

        localctx = SqlSmallParser.CharLengthFunctionContext(self, self._ctx, self.state)
        self.enterRule(localctx, 100, self.RULE_charLengthFunction)
        try:
            self.enterOuterAlt(localctx, 1)
            self.state = 639
            self.match(SqlSmallParser.CHAR_LENGTH)
            self.state = 640
            self.match(SqlSmallParser.T__1)
            self.state = 641
            localctx.sourceString = self.expression(0)
            self.state = 642
            self.match(SqlSmallParser.T__2)
        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class TruncFunctionContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser
            self.sourceExpr = None # ExpressionContext
            self.digits = None # NumberContext

        def TRUNC(self):
            return self.getToken(SqlSmallParser.TRUNC, 0)

        def TRUNCATE(self):
            return self.getToken(SqlSmallParser.TRUNCATE, 0)

        def expression(self):
            return self.getTypedRuleContext(SqlSmallParser.ExpressionContext,0)


        def number(self):
            return self.getTypedRuleContext(SqlSmallParser.NumberContext,0)


        def getRuleIndex(self):
            return SqlSmallParser.RULE_truncFunction

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterTruncFunction" ):
                listener.enterTruncFunction(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitTruncFunction" ):
                listener.exitTruncFunction(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitTruncFunction" ):
                return visitor.visitTruncFunction(self)
            else:
                return visitor.visitChildren(self)




    def truncFunction(self):

        localctx = SqlSmallParser.TruncFunctionContext(self, self._ctx, self.state)
        self.enterRule(localctx, 102, self.RULE_truncFunction)
        self._la = 0 # Token type
        try:
            self.enterOuterAlt(localctx, 1)
            self.state = 644
            _la = self._input.LA(1)
            if not(_la==SqlSmallParser.TRUNC or _la==SqlSmallParser.TRUNCATE):
                self._errHandler.recoverInline(self)
            else:
                self._errHandler.reportMatch(self)
                self.consume()
            self.state = 645
            self.match(SqlSmallParser.T__1)
            self.state = 646
            localctx.sourceExpr = self.expression(0)
            self.state = 649
            self._errHandler.sync(self)
            _la = self._input.LA(1)
            if _la==SqlSmallParser.T__3:
                self.state = 647
                self.match(SqlSmallParser.T__3)
                self.state = 648
                localctx.digits = self.number()


            self.state = 651
            self.match(SqlSmallParser.T__2)
        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class RoundFunctionContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser
            self.digits = None # NumberContext

        def ROUND(self):
            return self.getToken(SqlSmallParser.ROUND, 0)

        def expression(self):
            return self.getTypedRuleContext(SqlSmallParser.ExpressionContext,0)


        def number(self):
            return self.getTypedRuleContext(SqlSmallParser.NumberContext,0)


        def getRuleIndex(self):
            return SqlSmallParser.RULE_roundFunction

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterRoundFunction" ):
                listener.enterRoundFunction(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitRoundFunction" ):
                listener.exitRoundFunction(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitRoundFunction" ):
                return visitor.visitRoundFunction(self)
            else:
                return visitor.visitChildren(self)




    def roundFunction(self):

        localctx = SqlSmallParser.RoundFunctionContext(self, self._ctx, self.state)
        self.enterRule(localctx, 104, self.RULE_roundFunction)
        self._la = 0 # Token type
        try:
            self.enterOuterAlt(localctx, 1)
            self.state = 653
            self.match(SqlSmallParser.ROUND)
            self.state = 654
            self.match(SqlSmallParser.T__1)
            self.state = 655
            self.expression(0)
            self.state = 658
            self._errHandler.sync(self)
            _la = self._input.LA(1)
            if _la==SqlSmallParser.T__3:
                self.state = 656
                self.match(SqlSmallParser.T__3)
                self.state = 657
                localctx.digits = self.number()


            self.state = 660
            self.match(SqlSmallParser.T__2)
        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class PowerFunctionContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser

        def POWER(self):
            return self.getToken(SqlSmallParser.POWER, 0)

        def expression(self):
            return self.getTypedRuleContext(SqlSmallParser.ExpressionContext,0)


        def number(self):
            return self.getTypedRuleContext(SqlSmallParser.NumberContext,0)


        def getRuleIndex(self):
            return SqlSmallParser.RULE_powerFunction

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterPowerFunction" ):
                listener.enterPowerFunction(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitPowerFunction" ):
                listener.exitPowerFunction(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitPowerFunction" ):
                return visitor.visitPowerFunction(self)
            else:
                return visitor.visitChildren(self)




    def powerFunction(self):

        localctx = SqlSmallParser.PowerFunctionContext(self, self._ctx, self.state)
        self.enterRule(localctx, 106, self.RULE_powerFunction)
        try:
            self.enterOuterAlt(localctx, 1)
            self.state = 662
            self.match(SqlSmallParser.POWER)
            self.state = 663
            self.match(SqlSmallParser.T__1)
            self.state = 664
            self.expression(0)
            self.state = 665
            self.match(SqlSmallParser.T__3)
            self.state = 666
            self.number()
            self.state = 667
            self.match(SqlSmallParser.T__2)
        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class MathFunctionNameContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser

        def ABS(self):
            return self.getToken(SqlSmallParser.ABS, 0)

        def CEIL(self):
            return self.getToken(SqlSmallParser.CEIL, 0)

        def CEILING(self):
            return self.getToken(SqlSmallParser.CEILING, 0)

        def FLOOR(self):
            return self.getToken(SqlSmallParser.FLOOR, 0)

        def SIGN(self):
            return self.getToken(SqlSmallParser.SIGN, 0)

        def SQRT(self):
            return self.getToken(SqlSmallParser.SQRT, 0)

        def SQUARE(self):
            return self.getToken(SqlSmallParser.SQUARE, 0)

        def EXP(self):
            return self.getToken(SqlSmallParser.EXP, 0)

        def LN(self):
            return self.getToken(SqlSmallParser.LN, 0)

        def LOG(self):
            return self.getToken(SqlSmallParser.LOG, 0)

        def LOG10(self):
            return self.getToken(SqlSmallParser.LOG10, 0)

        def LOG2(self):
            return self.getToken(SqlSmallParser.LOG2, 0)

        def SIN(self):
            return self.getToken(SqlSmallParser.SIN, 0)

        def COS(self):
            return self.getToken(SqlSmallParser.COS, 0)

        def TAN(self):
            return self.getToken(SqlSmallParser.TAN, 0)

        def ASIN(self):
            return self.getToken(SqlSmallParser.ASIN, 0)

        def ACOS(self):
            return self.getToken(SqlSmallParser.ACOS, 0)

        def ATAN(self):
            return self.getToken(SqlSmallParser.ATAN, 0)

        def ATANH(self):
            return self.getToken(SqlSmallParser.ATANH, 0)

        def DEGREES(self):
            return self.getToken(SqlSmallParser.DEGREES, 0)

        def getRuleIndex(self):
            return SqlSmallParser.RULE_mathFunctionName

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterMathFunctionName" ):
                listener.enterMathFunctionName(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitMathFunctionName" ):
                listener.exitMathFunctionName(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitMathFunctionName" ):
                return visitor.visitMathFunctionName(self)
            else:
                return visitor.visitChildren(self)




    def mathFunctionName(self):

        localctx = SqlSmallParser.MathFunctionNameContext(self, self._ctx, self.state)
        self.enterRule(localctx, 108, self.RULE_mathFunctionName)
        self._la = 0 # Token type
        try:
            self.enterOuterAlt(localctx, 1)
            self.state = 669
            _la = self._input.LA(1)
            if not((((_la) & ~0x3f) == 0 and ((1 << _la) & ((1 << SqlSmallParser.ABS) | (1 << SqlSmallParser.ACOS) | (1 << SqlSmallParser.ASIN) | (1 << SqlSmallParser.ATAN) | (1 << SqlSmallParser.ATANH) | (1 << SqlSmallParser.CEIL) | (1 << SqlSmallParser.CEILING) | (1 << SqlSmallParser.COS) | (1 << SqlSmallParser.DEGREES) | (1 << SqlSmallParser.EXP) | (1 << SqlSmallParser.FLOOR))) != 0) or ((((_la - 68)) & ~0x3f) == 0 and ((1 << (_la - 68)) & ((1 << (SqlSmallParser.LN - 68)) | (1 << (SqlSmallParser.LOG - 68)) | (1 << (SqlSmallParser.LOG10 - 68)) | (1 << (SqlSmallParser.LOG2 - 68)) | (1 << (SqlSmallParser.SIGN - 68)) | (1 << (SqlSmallParser.SIN - 68)) | (1 << (SqlSmallParser.SQRT - 68)) | (1 << (SqlSmallParser.SQUARE - 68)) | (1 << (SqlSmallParser.TAN - 68)))) != 0)):
                self._errHandler.recoverInline(self)
            else:
                self._errHandler.reportMatch(self)
                self.consume()
        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class BareFunctionNameContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser

        def PI(self):
            return self.getToken(SqlSmallParser.PI, 0)

        def RANDOM(self):
            return self.getToken(SqlSmallParser.RANDOM, 0)

        def RAND(self):
            return self.getToken(SqlSmallParser.RAND, 0)

        def NEWID(self):
            return self.getToken(SqlSmallParser.NEWID, 0)

        def getRuleIndex(self):
            return SqlSmallParser.RULE_bareFunctionName

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterBareFunctionName" ):
                listener.enterBareFunctionName(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitBareFunctionName" ):
                listener.exitBareFunctionName(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitBareFunctionName" ):
                return visitor.visitBareFunctionName(self)
            else:
                return visitor.visitChildren(self)




    def bareFunctionName(self):

        localctx = SqlSmallParser.BareFunctionNameContext(self, self._ctx, self.state)
        self.enterRule(localctx, 110, self.RULE_bareFunctionName)
        self._la = 0 # Token type
        try:
            self.enterOuterAlt(localctx, 1)
            self.state = 671
            _la = self._input.LA(1)
            if not(((((_la - 79)) & ~0x3f) == 0 and ((1 << (_la - 79)) & ((1 << (SqlSmallParser.NEWID - 79)) | (1 << (SqlSmallParser.PI - 79)) | (1 << (SqlSmallParser.RAND - 79)) | (1 << (SqlSmallParser.RANDOM - 79)))) != 0)):
                self._errHandler.recoverInline(self)
            else:
                self._errHandler.reportMatch(self)
                self.consume()
        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class RankingFunctionNameContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser

        def ROW_NUMBER(self):
            return self.getToken(SqlSmallParser.ROW_NUMBER, 0)

        def RANK(self):
            return self.getToken(SqlSmallParser.RANK, 0)

        def DENSE_RANK(self):
            return self.getToken(SqlSmallParser.DENSE_RANK, 0)

        def getRuleIndex(self):
            return SqlSmallParser.RULE_rankingFunctionName

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterRankingFunctionName" ):
                listener.enterRankingFunctionName(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitRankingFunctionName" ):
                listener.exitRankingFunctionName(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitRankingFunctionName" ):
                return visitor.visitRankingFunctionName(self)
            else:
                return visitor.visitChildren(self)




    def rankingFunctionName(self):

        localctx = SqlSmallParser.RankingFunctionNameContext(self, self._ctx, self.state)
        self.enterRule(localctx, 112, self.RULE_rankingFunctionName)
        self._la = 0 # Token type
        try:
            self.enterOuterAlt(localctx, 1)
            self.state = 673
            _la = self._input.LA(1)
            if not(((((_la - 41)) & ~0x3f) == 0 and ((1 << (_la - 41)) & ((1 << (SqlSmallParser.DENSE_RANK - 41)) | (1 << (SqlSmallParser.RANK - 41)) | (1 << (SqlSmallParser.ROW_NUMBER - 41)))) != 0)):
                self._errHandler.recoverInline(self)
            else:
                self._errHandler.reportMatch(self)
                self.consume()
        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class AggregateFunctionNameContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser

        def COUNT(self):
            return self.getToken(SqlSmallParser.COUNT, 0)

        def SUM(self):
            return self.getToken(SqlSmallParser.SUM, 0)

        def AVG(self):
            return self.getToken(SqlSmallParser.AVG, 0)

        def VAR(self):
            return self.getToken(SqlSmallParser.VAR, 0)

        def VARIANCE(self):
            return self.getToken(SqlSmallParser.VARIANCE, 0)

        def STD(self):
            return self.getToken(SqlSmallParser.STD, 0)

        def STDDEV(self):
            return self.getToken(SqlSmallParser.STDDEV, 0)

        def STDEV(self):
            return self.getToken(SqlSmallParser.STDEV, 0)

        def MIN(self):
            return self.getToken(SqlSmallParser.MIN, 0)

        def MAX(self):
            return self.getToken(SqlSmallParser.MAX, 0)

        def PERCENTILE_DISC(self):
            return self.getToken(SqlSmallParser.PERCENTILE_DISC, 0)

        def PERCENTILE_CONT(self):
            return self.getToken(SqlSmallParser.PERCENTILE_CONT, 0)

        def getRuleIndex(self):
            return SqlSmallParser.RULE_aggregateFunctionName

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterAggregateFunctionName" ):
                listener.enterAggregateFunctionName(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitAggregateFunctionName" ):
                listener.exitAggregateFunctionName(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitAggregateFunctionName" ):
                return visitor.visitAggregateFunctionName(self)
            else:
                return visitor.visitChildren(self)




    def aggregateFunctionName(self):

        localctx = SqlSmallParser.AggregateFunctionNameContext(self, self._ctx, self.state)
        self.enterRule(localctx, 114, self.RULE_aggregateFunctionName)
        self._la = 0 # Token type
        try:
            self.enterOuterAlt(localctx, 1)
            self.state = 675
            _la = self._input.LA(1)
            if not(_la==SqlSmallParser.AVG or _la==SqlSmallParser.COUNT or ((((_la - 73)) & ~0x3f) == 0 and ((1 << (_la - 73)) & ((1 << (SqlSmallParser.MAX - 73)) | (1 << (SqlSmallParser.MIN - 73)) | (1 << (SqlSmallParser.PERCENTILE_CONT - 73)) | (1 << (SqlSmallParser.PERCENTILE_DISC - 73)) | (1 << (SqlSmallParser.STD - 73)) | (1 << (SqlSmallParser.STDDEV - 73)) | (1 << (SqlSmallParser.STDEV - 73)) | (1 << (SqlSmallParser.SUM - 73)) | (1 << (SqlSmallParser.VAR - 73)) | (1 << (SqlSmallParser.VARIANCE - 73)))) != 0)):
                self._errHandler.recoverInline(self)
            else:
                self._errHandler.reportMatch(self)
                self.consume()
        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class OverClauseContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser

        def OVER(self):
            return self.getToken(SqlSmallParser.OVER, 0)

        def PARTITION(self):
            return self.getToken(SqlSmallParser.PARTITION, 0)

        def BY(self):
            return self.getToken(SqlSmallParser.BY, 0)

        def expression(self):
            return self.getTypedRuleContext(SqlSmallParser.ExpressionContext,0)


        def orderClause(self):
            return self.getTypedRuleContext(SqlSmallParser.OrderClauseContext,0)


        def getRuleIndex(self):
            return SqlSmallParser.RULE_overClause

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterOverClause" ):
                listener.enterOverClause(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitOverClause" ):
                listener.exitOverClause(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitOverClause" ):
                return visitor.visitOverClause(self)
            else:
                return visitor.visitChildren(self)




    def overClause(self):

        localctx = SqlSmallParser.OverClauseContext(self, self._ctx, self.state)
        self.enterRule(localctx, 116, self.RULE_overClause)
        self._la = 0 # Token type
        try:
            self.enterOuterAlt(localctx, 1)
            self.state = 677
            self.match(SqlSmallParser.OVER)
            self.state = 678
            self.match(SqlSmallParser.T__1)
            self.state = 682
            self._errHandler.sync(self)
            _la = self._input.LA(1)
            if _la==SqlSmallParser.PARTITION:
                self.state = 679
                self.match(SqlSmallParser.PARTITION)
                self.state = 680
                self.match(SqlSmallParser.BY)
                self.state = 681
                self.expression(0)


            self.state = 685
            self._errHandler.sync(self)
            _la = self._input.LA(1)
            if _la==SqlSmallParser.ORDER:
                self.state = 684
                self.orderClause()


            self.state = 687
            self.match(SqlSmallParser.T__2)
        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class AliasedSubqueryContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser
            self.alias = None # IdentifierContext

        def subquery(self):
            return self.getTypedRuleContext(SqlSmallParser.SubqueryContext,0)


        def AS(self):
            return self.getToken(SqlSmallParser.AS, 0)

        def identifier(self):
            return self.getTypedRuleContext(SqlSmallParser.IdentifierContext,0)


        def getRuleIndex(self):
            return SqlSmallParser.RULE_aliasedSubquery

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterAliasedSubquery" ):
                listener.enterAliasedSubquery(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitAliasedSubquery" ):
                listener.exitAliasedSubquery(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitAliasedSubquery" ):
                return visitor.visitAliasedSubquery(self)
            else:
                return visitor.visitChildren(self)




    def aliasedSubquery(self):

        localctx = SqlSmallParser.AliasedSubqueryContext(self, self._ctx, self.state)
        self.enterRule(localctx, 118, self.RULE_aliasedSubquery)
        self._la = 0 # Token type
        try:
            self.enterOuterAlt(localctx, 1)
            self.state = 689
            self.subquery()
            self.state = 692
            self._errHandler.sync(self)
            _la = self._input.LA(1)
            if _la==SqlSmallParser.AS:
                self.state = 690
                self.match(SqlSmallParser.AS)
                self.state = 691
                localctx.alias = self.identifier()


        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class AliasedTableOrSubquerySeqContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser

        def aliasedTableName(self, i:int=None):
            if i is None:
                return self.getTypedRuleContexts(SqlSmallParser.AliasedTableNameContext)
            else:
                return self.getTypedRuleContext(SqlSmallParser.AliasedTableNameContext,i)


        def aliasedSubquery(self, i:int=None):
            if i is None:
                return self.getTypedRuleContexts(SqlSmallParser.AliasedSubqueryContext)
            else:
                return self.getTypedRuleContext(SqlSmallParser.AliasedSubqueryContext,i)


        def getRuleIndex(self):
            return SqlSmallParser.RULE_aliasedTableOrSubquerySeq

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterAliasedTableOrSubquerySeq" ):
                listener.enterAliasedTableOrSubquerySeq(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitAliasedTableOrSubquerySeq" ):
                listener.exitAliasedTableOrSubquerySeq(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitAliasedTableOrSubquerySeq" ):
                return visitor.visitAliasedTableOrSubquerySeq(self)
            else:
                return visitor.visitChildren(self)




    def aliasedTableOrSubquerySeq(self):

        localctx = SqlSmallParser.AliasedTableOrSubquerySeqContext(self, self._ctx, self.state)
        self.enterRule(localctx, 120, self.RULE_aliasedTableOrSubquerySeq)
        self._la = 0 # Token type
        try:
            self.enterOuterAlt(localctx, 1)
            self.state = 696
            self._errHandler.sync(self)
            token = self._input.LA(1)
            if token in [SqlSmallParser.QN2, SqlSmallParser.QN3, SqlSmallParser.IDENT]:
                self.state = 694
                self.aliasedTableName()
                pass
            elif token in [SqlSmallParser.T__1]:
                self.state = 695
                self.aliasedSubquery()
                pass
            else:
                raise NoViableAltException(self)

            self.state = 705
            self._errHandler.sync(self)
            _la = self._input.LA(1)
            while _la==SqlSmallParser.T__3:
                self.state = 698
                self.match(SqlSmallParser.T__3)
                self.state = 701
                self._errHandler.sync(self)
                token = self._input.LA(1)
                if token in [SqlSmallParser.QN2, SqlSmallParser.QN3, SqlSmallParser.IDENT]:
                    self.state = 699
                    self.aliasedTableName()
                    pass
                elif token in [SqlSmallParser.T__1]:
                    self.state = 700
                    self.aliasedSubquery()
                    pass
                else:
                    raise NoViableAltException(self)

                self.state = 707
                self._errHandler.sync(self)
                _la = self._input.LA(1)

        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class AliasedTableSeqContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser

        def aliasedTableName(self, i:int=None):
            if i is None:
                return self.getTypedRuleContexts(SqlSmallParser.AliasedTableNameContext)
            else:
                return self.getTypedRuleContext(SqlSmallParser.AliasedTableNameContext,i)


        def getRuleIndex(self):
            return SqlSmallParser.RULE_aliasedTableSeq

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterAliasedTableSeq" ):
                listener.enterAliasedTableSeq(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitAliasedTableSeq" ):
                listener.exitAliasedTableSeq(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitAliasedTableSeq" ):
                return visitor.visitAliasedTableSeq(self)
            else:
                return visitor.visitChildren(self)




    def aliasedTableSeq(self):

        localctx = SqlSmallParser.AliasedTableSeqContext(self, self._ctx, self.state)
        self.enterRule(localctx, 122, self.RULE_aliasedTableSeq)
        self._la = 0 # Token type
        try:
            self.enterOuterAlt(localctx, 1)
            self.state = 708
            self.aliasedTableName()
            self.state = 713
            self._errHandler.sync(self)
            _la = self._input.LA(1)
            while _la==SqlSmallParser.T__3:
                self.state = 709
                self.match(SqlSmallParser.T__3)
                self.state = 710
                self.aliasedTableName()
                self.state = 715
                self._errHandler.sync(self)
                _la = self._input.LA(1)

        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class AliasedTableNameContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser
            self.alias = None # IdentifierContext

        def qualifiedTableName(self):
            return self.getTypedRuleContext(SqlSmallParser.QualifiedTableNameContext,0)


        def AS(self):
            return self.getToken(SqlSmallParser.AS, 0)

        def identifier(self):
            return self.getTypedRuleContext(SqlSmallParser.IdentifierContext,0)


        def getRuleIndex(self):
            return SqlSmallParser.RULE_aliasedTableName

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterAliasedTableName" ):
                listener.enterAliasedTableName(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitAliasedTableName" ):
                listener.exitAliasedTableName(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitAliasedTableName" ):
                return visitor.visitAliasedTableName(self)
            else:
                return visitor.visitChildren(self)




    def aliasedTableName(self):

        localctx = SqlSmallParser.AliasedTableNameContext(self, self._ctx, self.state)
        self.enterRule(localctx, 124, self.RULE_aliasedTableName)
        self._la = 0 # Token type
        try:
            self.enterOuterAlt(localctx, 1)
            self.state = 716
            self.qualifiedTableName()
            self.state = 719
            self._errHandler.sync(self)
            _la = self._input.LA(1)
            if _la==SqlSmallParser.AS:
                self.state = 717
                self.match(SqlSmallParser.AS)
                self.state = 718
                localctx.alias = self.identifier()


        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class QualifiedTableNameContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser

        def QN3(self):
            return self.getToken(SqlSmallParser.QN3, 0)

        def QN2(self):
            return self.getToken(SqlSmallParser.QN2, 0)

        def IDENT(self):
            return self.getToken(SqlSmallParser.IDENT, 0)

        def getRuleIndex(self):
            return SqlSmallParser.RULE_qualifiedTableName

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterQualifiedTableName" ):
                listener.enterQualifiedTableName(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitQualifiedTableName" ):
                listener.exitQualifiedTableName(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitQualifiedTableName" ):
                return visitor.visitQualifiedTableName(self)
            else:
                return visitor.visitChildren(self)




    def qualifiedTableName(self):

        localctx = SqlSmallParser.QualifiedTableNameContext(self, self._ctx, self.state)
        self.enterRule(localctx, 126, self.RULE_qualifiedTableName)
        self._la = 0 # Token type
        try:
            self.enterOuterAlt(localctx, 1)
            self.state = 721
            _la = self._input.LA(1)
            if not(((((_la - 158)) & ~0x3f) == 0 and ((1 << (_la - 158)) & ((1 << (SqlSmallParser.QN2 - 158)) | (1 << (SqlSmallParser.QN3 - 158)) | (1 << (SqlSmallParser.IDENT - 158)))) != 0)):
                self._errHandler.recoverInline(self)
            else:
                self._errHandler.reportMatch(self)
                self.consume()
        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class QualifiedColumnNameContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser

        def QN2(self):
            return self.getToken(SqlSmallParser.QN2, 0)

        def IDENT(self):
            return self.getToken(SqlSmallParser.IDENT, 0)

        def STRING(self):
            return self.getToken(SqlSmallParser.STRING, 0)

        def getRuleIndex(self):
            return SqlSmallParser.RULE_qualifiedColumnName

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterQualifiedColumnName" ):
                listener.enterQualifiedColumnName(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitQualifiedColumnName" ):
                listener.exitQualifiedColumnName(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitQualifiedColumnName" ):
                return visitor.visitQualifiedColumnName(self)
            else:
                return visitor.visitChildren(self)




    def qualifiedColumnName(self):

        localctx = SqlSmallParser.QualifiedColumnNameContext(self, self._ctx, self.state)
        self.enterRule(localctx, 128, self.RULE_qualifiedColumnName)
        try:
            self.state = 728
            self._errHandler.sync(self)
            token = self._input.LA(1)
            if token in [SqlSmallParser.QN2]:
                self.enterOuterAlt(localctx, 1)
                self.state = 723
                self.match(SqlSmallParser.QN2)
                pass
            elif token in [SqlSmallParser.IDENT]:
                self.enterOuterAlt(localctx, 2)
                self.state = 724
                self.match(SqlSmallParser.IDENT)
                pass
            elif token in [SqlSmallParser.T__5]:
                self.enterOuterAlt(localctx, 3)
                self.state = 725
                self.match(SqlSmallParser.T__5)
                self.state = 726
                self.match(SqlSmallParser.STRING)
                self.state = 727
                self.match(SqlSmallParser.T__5)
                pass
            else:
                raise NoViableAltException(self)

        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class IdentifierContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser

        def IDENT(self):
            return self.getToken(SqlSmallParser.IDENT, 0)

        def getRuleIndex(self):
            return SqlSmallParser.RULE_identifier

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterIdentifier" ):
                listener.enterIdentifier(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitIdentifier" ):
                listener.exitIdentifier(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitIdentifier" ):
                return visitor.visitIdentifier(self)
            else:
                return visitor.visitChildren(self)




    def identifier(self):

        localctx = SqlSmallParser.IdentifierContext(self, self._ctx, self.state)
        self.enterRule(localctx, 130, self.RULE_identifier)
        try:
            self.enterOuterAlt(localctx, 1)
            self.state = 730
            self.match(SqlSmallParser.IDENT)
        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx


    class NumberContext(ParserRuleContext):
        __slots__ = 'parser'

        def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
            super().__init__(parent, invokingState)
            self.parser = parser


        def getRuleIndex(self):
            return SqlSmallParser.RULE_number

     
        def copyFrom(self, ctx:ParserRuleContext):
            super().copyFrom(ctx)



    class DecimalLiteralContext(NumberContext):

        def __init__(self, parser, ctx:ParserRuleContext): # actually a SqlSmallParser.NumberContext
            super().__init__(parser)
            self.copyFrom(ctx)

        def DECIMAL_VALUE(self):
            return self.getToken(SqlSmallParser.DECIMAL_VALUE, 0)
        def MINUS(self):
            return self.getToken(SqlSmallParser.MINUS, 0)

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterDecimalLiteral" ):
                listener.enterDecimalLiteral(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitDecimalLiteral" ):
                listener.exitDecimalLiteral(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitDecimalLiteral" ):
                return visitor.visitDecimalLiteral(self)
            else:
                return visitor.visitChildren(self)


    class IntegerLiteralContext(NumberContext):

        def __init__(self, parser, ctx:ParserRuleContext): # actually a SqlSmallParser.NumberContext
            super().__init__(parser)
            self.copyFrom(ctx)

        def INTEGER_VALUE(self):
            return self.getToken(SqlSmallParser.INTEGER_VALUE, 0)
        def MINUS(self):
            return self.getToken(SqlSmallParser.MINUS, 0)

        def enterRule(self, listener:ParseTreeListener):
            if hasattr( listener, "enterIntegerLiteral" ):
                listener.enterIntegerLiteral(self)

        def exitRule(self, listener:ParseTreeListener):
            if hasattr( listener, "exitIntegerLiteral" ):
                listener.exitIntegerLiteral(self)

        def accept(self, visitor:ParseTreeVisitor):
            if hasattr( visitor, "visitIntegerLiteral" ):
                return visitor.visitIntegerLiteral(self)
            else:
                return visitor.visitChildren(self)



    def number(self):

        localctx = SqlSmallParser.NumberContext(self, self._ctx, self.state)
        self.enterRule(localctx, 132, self.RULE_number)
        self._la = 0 # Token type
        try:
            self.state = 740
            self._errHandler.sync(self)
            la_ = self._interp.adaptivePredict(self._input,75,self._ctx)
            if la_ == 1:
                localctx = SqlSmallParser.DecimalLiteralContext(self, localctx)
                self.enterOuterAlt(localctx, 1)
                self.state = 733
                self._errHandler.sync(self)
                _la = self._input.LA(1)
                if _la==SqlSmallParser.MINUS:
                    self.state = 732
                    self.match(SqlSmallParser.MINUS)


                self.state = 735
                self.match(SqlSmallParser.DECIMAL_VALUE)
                pass

            elif la_ == 2:
                localctx = SqlSmallParser.IntegerLiteralContext(self, localctx)
                self.enterOuterAlt(localctx, 2)
                self.state = 737
                self._errHandler.sync(self)
                _la = self._input.LA(1)
                if _la==SqlSmallParser.MINUS:
                    self.state = 736
                    self.match(SqlSmallParser.MINUS)


                self.state = 739
                self.match(SqlSmallParser.INTEGER_VALUE)
                pass


        except RecognitionException as re:
            localctx.exception = re
            self._errHandler.reportError(self, re)
            self._errHandler.recover(self, re)
        finally:
            self.exitRule()
        return localctx



    def sempred(self, localctx:RuleContext, ruleIndex:int, predIndex:int):
        if self._predicates == None:
            self._predicates = dict()
        self._predicates[24] = self.expression_sempred
        self._predicates[27] = self.booleanExpression_sempred
        pred = self._predicates.get(ruleIndex, None)
        if pred is None:
            raise Exception("No predicate with index:" + str(ruleIndex))
        else:
            return pred(localctx, predIndex)

    def expression_sempred(self, localctx:ExpressionContext, predIndex:int):
            if predIndex == 0:
                return self.precpred(self._ctx, 17)
         

            if predIndex == 1:
                return self.precpred(self._ctx, 16)
         

            if predIndex == 2:
                return self.precpred(self._ctx, 15)
         

            if predIndex == 3:
                return self.precpred(self._ctx, 14)
         

            if predIndex == 4:
                return self.precpred(self._ctx, 13)
         

    def booleanExpression_sempred(self, localctx:BooleanExpressionContext, predIndex:int):
            if predIndex == 5:
                return self.precpred(self._ctx, 5)
         

            if predIndex == 6:
                return self.precpred(self._ctx, 4)
         




