From 77f9b0df8995502d7fd77444bacd5085c5b08a45 Mon Sep 17 00:00:00 2001 From: Zhengda Lu Date: Wed, 15 May 2024 08:20:39 -0400 Subject: [PATCH] Fix bug where table name is not properly collected on drop statement --- normalizer_test.go | 11 +++++++++++ sqllexer_test.go | 15 +++++++++++++++ sqllexer_utils.go | 2 ++ 3 files changed, 28 insertions(+) diff --git a/normalizer_test.go b/normalizer_test.go index 77df919..00093ac 100644 --- a/normalizer_test.go +++ b/normalizer_test.go @@ -357,6 +357,17 @@ multiline comment */ Size: 11, }, }, + { + input: `DROP TABLE IF EXISTS users`, + expected: `DROP TABLE IF EXISTS users`, + statementMetadata: StatementMetadata{ + Tables: []string{"users"}, + Comments: []string{}, + Commands: []string{"DROP"}, + Procedures: []string{}, + Size: 9, + }, + }, } normalizer := NewNormalizer( diff --git a/sqllexer_test.go b/sqllexer_test.go index c9ecf1a..7a1ab29 100644 --- a/sqllexer_test.go +++ b/sqllexer_test.go @@ -632,6 +632,21 @@ func TestLexer(t *testing.T) { }, lexerOpts: []lexerOption{WithDBMS(DBMSMySQL)}, }, + { + name: "drop table if exists", + input: `DROP TABLE IF EXISTS users`, + expected: []Token{ + {IDENT, "DROP"}, + {WS, " "}, + {IDENT, "TABLE"}, + {WS, " "}, + {IDENT, "IF"}, + {WS, " "}, + {IDENT, "EXISTS"}, + {WS, " "}, + {IDENT, "users"}, + }, + }, } for _, tt := range tests { diff --git a/sqllexer_utils.go b/sqllexer_utils.go index f694ce7..e6866d5 100644 --- a/sqllexer_utils.go +++ b/sqllexer_utils.go @@ -49,6 +49,7 @@ var tableIndicators = map[string]bool{ "INTO": true, "UPDATE": true, "TABLE": true, + "EXISTS": true, // Drop Table If Exists "STRAIGHT_JOIN": true, // MySQL "CLONE": true, // Snowflake } @@ -145,6 +146,7 @@ var keywords = map[string]bool{ "OFFSET": true, "OF": true, "SKIP": true, + "IF": true, } func isWhitespace(ch rune) bool {