Skip to content

Commit

Permalink
improved sql parser support, fix #3947
Browse files Browse the repository at this point in the history
  • Loading branch information
wenshao committed Oct 6, 2020
1 parent f5dd23f commit b6a0fb5
Show file tree
Hide file tree
Showing 3 changed files with 12 additions and 1 deletion.
3 changes: 3 additions & 0 deletions src/main/java/com/alibaba/druid/sql/SQLUtils.java
Original file line number Diff line number Diff line change
Expand Up @@ -585,6 +585,9 @@ public static SQLStatement parseSingleStatement(String sql, DbType dbType, boole
return stmtList.get(0);
}

public static SQLStatement parseSingleStatement(String sql, String dbType, SQLParserFeature... features) {
return parseSingleStatement(sql, DbType.of(dbType), features);
}

public static SQLStatement parseSingleStatement(String sql, DbType dbType, SQLParserFeature... features) {
SQLStatementParser parser = SQLParserUtils.createSQLStatementParser(sql, dbType, features);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -4442,7 +4442,9 @@ public SQLAssignItem parseAssignItem(boolean variant) {
} else if (dbType == DbType.db2) {
} else if (lexer.token == Token.QUES
|| lexer.token == Token.LITERAL_CHARS
|| lexer.token == Token.LITERAL_ALIAS) {
|| lexer.token == Token.LITERAL_ALIAS
|| lexer.identifierEquals("utf8mb4")
) {
// skip
} else {
accept(Token.EQ);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@
*/
package com.alibaba.druid.bvt.sql.mysql;

import com.alibaba.druid.DbType;
import com.alibaba.druid.sql.SQLUtils;
import com.alibaba.druid.sql.ast.SQLStatement;
import com.alibaba.druid.sql.dialect.mysql.parser.MySqlStatementParser;
Expand Down Expand Up @@ -52,4 +53,9 @@ public void test_0() throws Exception {

Assert.assertEquals("SET sql_mode = ?, NAMES ?, CHARACTER SET utf8, CHARACTER_SET_RESULTS = utf8, COLLATION_CONNECTION = ?", text);
}

public void test_1() throws Exception {
SQLUtils.parseSingleStatement("set names utf8mb4", "mysql");
SQLUtils.parseSingleStatement("set names utf8mb4", (DbType) null);
}
}

0 comments on commit b6a0fb5

Please sign in to comment.