From 90dbb27e0bee7f11157b81b391373194a8bc9a92 Mon Sep 17 00:00:00 2001 From: Zhengda Lu Date: Mon, 5 Aug 2024 10:38:38 -0400 Subject: [PATCH] fix table name for select only statement --- normalizer_test.go | 11 ++++++++++ sqllexer_test.go | 23 +++++++++++++++++++++ sqllexer_utils.go | 2 ++ testdata/postgresql/select/select-only.json | 20 ++++++++++++++++++ 4 files changed, 56 insertions(+) create mode 100644 testdata/postgresql/select/select-only.json diff --git a/normalizer_test.go b/normalizer_test.go index 00093ac..e3e36d1 100644 --- a/normalizer_test.go +++ b/normalizer_test.go @@ -368,6 +368,17 @@ multiline comment */ Size: 9, }, }, + { + input: "SELECT * FROM ONLY users WHERE id = ?", + expected: "SELECT * FROM ONLY users WHERE id = ?", + statementMetadata: StatementMetadata{ + Tables: []string{"users"}, + Comments: []string{}, + Commands: []string{"SELECT"}, + Procedures: []string{}, + Size: 11, + }, + }, } normalizer := NewNormalizer( diff --git a/sqllexer_test.go b/sqllexer_test.go index 7a1ab29..359bbd9 100644 --- a/sqllexer_test.go +++ b/sqllexer_test.go @@ -647,6 +647,29 @@ func TestLexer(t *testing.T) { {IDENT, "users"}, }, }, + { + name: "select only", + input: "SELECT * FROM ONLY tab1 where id = 1", + expected: []Token{ + {IDENT, "SELECT"}, + {WS, " "}, + {WILDCARD, "*"}, + {WS, " "}, + {IDENT, "FROM"}, + {WS, " "}, + {IDENT, "ONLY"}, + {WS, " "}, + {IDENT, "tab1"}, + {WS, " "}, + {IDENT, "where"}, + {WS, " "}, + {IDENT, "id"}, + {WS, " "}, + {OPERATOR, "="}, + {WS, " "}, + {NUMBER, "1"}, + }, + }, } for _, tt := range tests { diff --git a/sqllexer_utils.go b/sqllexer_utils.go index e6866d5..5046525 100644 --- a/sqllexer_utils.go +++ b/sqllexer_utils.go @@ -52,6 +52,7 @@ var tableIndicators = map[string]bool{ "EXISTS": true, // Drop Table If Exists "STRAIGHT_JOIN": true, // MySQL "CLONE": true, // Snowflake + "ONLY": true, // PostgreSQL } var keywords = map[string]bool{ @@ -147,6 +148,7 @@ var keywords = map[string]bool{ "OF": true, "SKIP": true, "IF": true, + "ONLY": true, } func isWhitespace(ch rune) bool { diff --git a/testdata/postgresql/select/select-only.json b/testdata/postgresql/select/select-only.json new file mode 100644 index 0000000..99b7413 --- /dev/null +++ b/testdata/postgresql/select/select-only.json @@ -0,0 +1,20 @@ +{ + "input": "SELECT * FROM ONLY users, ONLY orders WHERE users.id = orders.user_id;", + "outputs": [ + { + "expected": "SELECT * FROM ONLY users, ONLY orders WHERE users.id = orders.user_id", + "statement_metadata": { + "size": 17, + "tables": [ + "users", + "orders" + ], + "commands": [ + "SELECT" + ], + "comments": [], + "procedures": [] + } + } + ] +} \ No newline at end of file