Skip to content

Commit f0c2623

Browse files
committed
[SPARK-47482] Add HiveDialect to sql module
1 parent 2b0e841 commit f0c2623

File tree

2 files changed

+30
-0
lines changed

2 files changed

+30
-0
lines changed
Lines changed: 29 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,29 @@
1+
/*
2+
* Licensed to the Apache Software Foundation (ASF) under one or more
3+
* contributor license agreements. See the NOTICE file distributed with
4+
* this work for additional information regarding copyright ownership.
5+
* The ASF licenses this file to You under the Apache License, Version 2.0
6+
* (the "License"); you may not use this file except in compliance with
7+
* the License. You may obtain a copy of the License at
8+
*
9+
* http://www.apache.org/licenses/LICENSE-2.0
10+
*
11+
* Unless required by applicable law or agreed to in writing, software
12+
* distributed under the License is distributed on an "AS IS" BASIS,
13+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14+
* See the License for the specific language governing permissions and
15+
* limitations under the License.
16+
*/
17+
18+
package org.apache.spark.sql.jdbc
19+
20+
import java.util.Locale
21+
22+
private case class HiveDialect() extends JdbcDialect {
23+
override def canHandle(url: String): Boolean =
24+
url.toLowerCase(Locale.ROOT).startsWith("jdbc:hive2")
25+
26+
override def quoteIdentifier(colName: String): String = {
27+
s"`$colName`"
28+
}
29+
}

sql/core/src/test/scala/org/apache/spark/sql/jdbc/JDBCSuite.scala

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -787,6 +787,7 @@ class JDBCSuite extends QueryTest with SharedSparkSession {
787787

788788
test("Default jdbc dialect registration") {
789789
assert(JdbcDialects.get("jdbc:mysql://127.0.0.1/db") === MySQLDialect())
790+
assert(JdbcDialects.get("jdbc:hive2://127.0.0.1/db") === HiveDialect())
790791
assert(JdbcDialects.get("jdbc:postgresql://127.0.0.1/db") === PostgresDialect())
791792
assert(JdbcDialects.get("jdbc:db2://127.0.0.1/db") === DB2Dialect())
792793
assert(JdbcDialects.get("jdbc:sqlserver://127.0.0.1/db") === MsSqlServerDialect())

0 commit comments

Comments
 (0)