Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Contribute to GitLab
Sign in / Register
Toggle navigation
D
dlink
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
zhaowei
dlink
Commits
d0146a4d
Unverified
Commit
d0146a4d
authored
Aug 17, 2022
by
xiaofeng
Committed by
GitHub
Aug 17, 2022
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Optimized connection pooling and connection creation (#900)
Co-authored-by:
liuxiaofeng
<
liuxiaofeng@xcxd.com
>
parent
c005a002
Changes
5
Show whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
78 additions
and
56 deletions
+78
-56
AbstractJdbcDriver.java
...in/java/com/dlink/metadata/driver/AbstractJdbcDriver.java
+44
-38
Driver.java
...-base/src/main/java/com/dlink/metadata/driver/Driver.java
+22
-9
ClickHouseDriver.java
...main/java/com/dlink/metadata/driver/ClickHouseDriver.java
+1
-1
HiveDriver.java
...e/src/main/java/com/dlink/metadata/driver/HiveDriver.java
+6
-6
PhoenixDriver.java
...rc/main/java/com/dlink/metadata/driver/PhoenixDriver.java
+5
-2
No files found.
dlink-metadata/dlink-metadata-base/src/main/java/com/dlink/metadata/driver/AbstractJdbcDriver.java
View file @
d0146a4d
...
@@ -21,6 +21,7 @@
...
@@ -21,6 +21,7 @@
package
com
.
dlink
.
metadata
.
driver
;
package
com
.
dlink
.
metadata
.
driver
;
import
com.alibaba.druid.pool.DruidDataSource
;
import
com.alibaba.druid.pool.DruidDataSource
;
import
com.alibaba.druid.pool.DruidPooledConnection
;
import
com.alibaba.druid.sql.SQLUtils
;
import
com.alibaba.druid.sql.SQLUtils
;
import
com.alibaba.druid.sql.ast.SQLStatement
;
import
com.alibaba.druid.sql.ast.SQLStatement
;
import
com.dlink.assertion.Asserts
;
import
com.dlink.assertion.Asserts
;
...
@@ -48,7 +49,7 @@ public abstract class AbstractJdbcDriver extends AbstractDriver {
...
@@ -48,7 +49,7 @@ public abstract class AbstractJdbcDriver extends AbstractDriver {
private
static
Logger
logger
=
LoggerFactory
.
getLogger
(
AbstractJdbcDriver
.
class
);
private
static
Logger
logger
=
LoggerFactory
.
getLogger
(
AbstractJdbcDriver
.
class
);
protected
Connection
conn
;
protected
static
ThreadLocal
<
Connection
>
conn
=
new
ThreadLocal
<>()
;
private
DruidDataSource
dataSource
;
private
DruidDataSource
dataSource
;
...
@@ -67,13 +68,14 @@ public abstract class AbstractJdbcDriver extends AbstractDriver {
...
@@ -67,13 +68,14 @@ public abstract class AbstractJdbcDriver extends AbstractDriver {
return
CommonConstant
.
HEALTHY
;
return
CommonConstant
.
HEALTHY
;
}
}
public
DruidDataSource
get
DataSource
()
throws
SQLException
{
public
DruidDataSource
create
DataSource
()
throws
SQLException
{
if
(
null
==
dataSource
)
{
if
(
null
==
dataSource
)
{
synchronized
(
this
)
{
synchronized
(
this
.
getClass
()
)
{
if
(
null
==
dataSource
)
{
if
(
null
==
dataSource
)
{
this
.
dataSource
=
new
DruidDataSource
();
DruidDataSource
ds
=
new
DruidDataSource
();
assembleConfig
(
config
);
createDataSource
(
ds
,
config
);
dataSource
.
init
();
ds
.
init
();
this
.
dataSource
=
ds
;
}
}
}
}
}
}
...
@@ -83,46 +85,48 @@ public abstract class AbstractJdbcDriver extends AbstractDriver {
...
@@ -83,46 +85,48 @@ public abstract class AbstractJdbcDriver extends AbstractDriver {
public
Driver
setDriverConfig
(
DriverConfig
config
)
{
public
Driver
setDriverConfig
(
DriverConfig
config
)
{
this
.
config
=
config
;
this
.
config
=
config
;
try
{
try
{
this
.
dataSource
=
get
DataSource
();
this
.
dataSource
=
create
DataSource
();
}
catch
(
SQLException
e
)
{
}
catch
(
SQLException
e
)
{
throw
new
RuntimeException
(
e
);
throw
new
RuntimeException
(
e
);
}
}
assembleConfig
(
config
);
createDataSource
(
dataSource
,
config
);
return
this
;
return
this
;
}
}
private
void
assembleConfig
(
DriverConfig
config
)
{
private
void
createDataSource
(
DruidDataSource
ds
,
DriverConfig
config
)
{
dataSource
.
setName
(
config
.
getName
());
ds
.
setName
(
config
.
getName
().
replaceAll
(
":"
,
""
));
dataSource
.
setUrl
(
config
.
getUrl
());
ds
.
setUrl
(
config
.
getUrl
());
dataSource
.
setDriverClassName
(
getDriverClass
());
ds
.
setDriverClassName
(
getDriverClass
());
dataSource
.
setUsername
(
config
.
getUsername
());
ds
.
setUsername
(
config
.
getUsername
());
dataSource
.
setPassword
(
config
.
getPassword
());
ds
.
setPassword
(
config
.
getPassword
());
dataSource
.
setValidationQuery
(
"select 1"
);
ds
.
setValidationQuery
(
"select 1"
);
dataSource
.
setTestOnBorrow
(
true
);
ds
.
setTestWhileIdle
(
true
);
dataSource
.
setTestWhileIdle
(
true
);
ds
.
setBreakAfterAcquireFailure
(
true
);
dataSource
.
setBreakAfterAcquireFailure
(
true
);
ds
.
setFailFast
(
true
);
dataSource
.
setFailFast
(
true
);
ds
.
setInitialSize
(
1
);
dataSource
.
setInitialSize
(
1
);
ds
.
setMaxActive
(
8
);
dataSource
.
setMaxActive
(
8
);
ds
.
setMinIdle
(
5
);
dataSource
.
setMinIdle
(
5
);
}
}
@Override
@Override
public
Driver
connect
()
{
public
Driver
connect
()
{
if
(
null
==
conn
.
get
())
{
try
{
try
{
Class
.
forName
(
getDriverClass
());
Class
.
forName
(
getDriverClass
());
conn
=
getDataSource
().
getConnection
();
DruidPooledConnection
connection
=
createDataSource
().
getConnection
();
conn
.
set
(
connection
);
}
catch
(
ClassNotFoundException
|
SQLException
e
)
{
}
catch
(
ClassNotFoundException
|
SQLException
e
)
{
throw
new
RuntimeException
(
e
);
throw
new
RuntimeException
(
e
);
}
}
}
return
this
;
return
this
;
}
}
@Override
@Override
public
boolean
isHealth
()
{
public
boolean
isHealth
()
{
try
{
try
{
if
(
Asserts
.
isNotNull
(
conn
))
{
if
(
Asserts
.
isNotNull
(
conn
.
get
()
))
{
return
!
conn
.
isClosed
();
return
!
conn
.
get
().
isClosed
();
}
}
return
false
;
return
false
;
}
catch
(
Exception
e
)
{
}
catch
(
Exception
e
)
{
...
@@ -134,8 +138,9 @@ public abstract class AbstractJdbcDriver extends AbstractDriver {
...
@@ -134,8 +138,9 @@ public abstract class AbstractJdbcDriver extends AbstractDriver {
@Override
@Override
public
void
close
()
{
public
void
close
()
{
try
{
try
{
if
(
Asserts
.
isNotNull
(
conn
))
{
if
(
Asserts
.
isNotNull
(
conn
.
get
()))
{
conn
.
close
();
conn
.
get
().
close
();
conn
.
remove
();
}
}
}
catch
(
SQLException
e
)
{
}
catch
(
SQLException
e
)
{
e
.
printStackTrace
();
e
.
printStackTrace
();
...
@@ -162,7 +167,7 @@ public abstract class AbstractJdbcDriver extends AbstractDriver {
...
@@ -162,7 +167,7 @@ public abstract class AbstractJdbcDriver extends AbstractDriver {
ResultSet
results
=
null
;
ResultSet
results
=
null
;
String
schemasSql
=
getDBQuery
().
schemaAllSql
();
String
schemasSql
=
getDBQuery
().
schemaAllSql
();
try
{
try
{
preparedStatement
=
conn
.
prepareStatement
(
schemasSql
);
preparedStatement
=
conn
.
get
().
prepareStatement
(
schemasSql
);
results
=
preparedStatement
.
executeQuery
();
results
=
preparedStatement
.
executeQuery
();
while
(
results
.
next
())
{
while
(
results
.
next
())
{
String
schemaName
=
results
.
getString
(
getDBQuery
().
schemaName
());
String
schemaName
=
results
.
getString
(
getDBQuery
().
schemaName
());
...
@@ -187,7 +192,7 @@ public abstract class AbstractJdbcDriver extends AbstractDriver {
...
@@ -187,7 +192,7 @@ public abstract class AbstractJdbcDriver extends AbstractDriver {
IDBQuery
dbQuery
=
getDBQuery
();
IDBQuery
dbQuery
=
getDBQuery
();
String
sql
=
dbQuery
.
tablesSql
(
schemaName
);
String
sql
=
dbQuery
.
tablesSql
(
schemaName
);
try
{
try
{
preparedStatement
=
conn
.
prepareStatement
(
sql
);
preparedStatement
=
conn
.
get
().
prepareStatement
(
sql
);
results
=
preparedStatement
.
executeQuery
();
results
=
preparedStatement
.
executeQuery
();
ResultSetMetaData
metaData
=
results
.
getMetaData
();
ResultSetMetaData
metaData
=
results
.
getMetaData
();
List
<
String
>
columnList
=
new
ArrayList
<>();
List
<
String
>
columnList
=
new
ArrayList
<>();
...
@@ -244,7 +249,7 @@ public abstract class AbstractJdbcDriver extends AbstractDriver {
...
@@ -244,7 +249,7 @@ public abstract class AbstractJdbcDriver extends AbstractDriver {
String
tableFieldsSql
=
dbQuery
.
columnsSql
(
schemaName
,
tableName
);
String
tableFieldsSql
=
dbQuery
.
columnsSql
(
schemaName
,
tableName
);
tableFieldsSql
=
String
.
format
(
tableFieldsSql
,
tableName
);
tableFieldsSql
=
String
.
format
(
tableFieldsSql
,
tableName
);
try
{
try
{
preparedStatement
=
conn
.
prepareStatement
(
tableFieldsSql
);
preparedStatement
=
conn
.
get
().
prepareStatement
(
tableFieldsSql
);
results
=
preparedStatement
.
executeQuery
();
results
=
preparedStatement
.
executeQuery
();
ResultSetMetaData
metaData
=
results
.
getMetaData
();
ResultSetMetaData
metaData
=
results
.
getMetaData
();
List
<
String
>
columnList
=
new
ArrayList
<>();
List
<
String
>
columnList
=
new
ArrayList
<>();
...
@@ -352,7 +357,7 @@ public abstract class AbstractJdbcDriver extends AbstractDriver {
...
@@ -352,7 +357,7 @@ public abstract class AbstractJdbcDriver extends AbstractDriver {
ResultSet
results
=
null
;
ResultSet
results
=
null
;
String
createTableSql
=
getDBQuery
().
createTableSql
(
table
.
getSchema
(),
table
.
getName
());
String
createTableSql
=
getDBQuery
().
createTableSql
(
table
.
getSchema
(),
table
.
getName
());
try
{
try
{
preparedStatement
=
conn
.
prepareStatement
(
createTableSql
);
preparedStatement
=
conn
.
get
().
prepareStatement
(
createTableSql
);
results
=
preparedStatement
.
executeQuery
();
results
=
preparedStatement
.
executeQuery
();
if
(
results
.
next
())
{
if
(
results
.
next
())
{
createTable
=
results
.
getString
(
getDBQuery
().
createTableName
());
createTable
=
results
.
getString
(
getDBQuery
().
createTableName
());
...
@@ -390,7 +395,8 @@ public abstract class AbstractJdbcDriver extends AbstractDriver {
...
@@ -390,7 +395,8 @@ public abstract class AbstractJdbcDriver extends AbstractDriver {
@Override
@Override
public
boolean
execute
(
String
sql
)
throws
Exception
{
public
boolean
execute
(
String
sql
)
throws
Exception
{
Asserts
.
checkNullString
(
sql
,
"Sql 语句为空"
);
Asserts
.
checkNullString
(
sql
,
"Sql 语句为空"
);
try
(
Statement
statement
=
conn
.
createStatement
())
{
try
(
Statement
statement
=
conn
.
get
().
createStatement
())
{
// logger.info("执行sql的连接id:" + ((DruidPooledConnection) conn).getTransactionInfo().getId());
statement
.
execute
(
sql
);
statement
.
execute
(
sql
);
}
}
return
true
;
return
true
;
...
@@ -400,7 +406,7 @@ public abstract class AbstractJdbcDriver extends AbstractDriver {
...
@@ -400,7 +406,7 @@ public abstract class AbstractJdbcDriver extends AbstractDriver {
public
int
executeUpdate
(
String
sql
)
throws
Exception
{
public
int
executeUpdate
(
String
sql
)
throws
Exception
{
Asserts
.
checkNullString
(
sql
,
"Sql 语句为空"
);
Asserts
.
checkNullString
(
sql
,
"Sql 语句为空"
);
int
res
=
0
;
int
res
=
0
;
try
(
Statement
statement
=
conn
.
createStatement
())
{
try
(
Statement
statement
=
conn
.
get
().
createStatement
())
{
res
=
statement
.
executeUpdate
(
sql
);
res
=
statement
.
executeUpdate
(
sql
);
}
}
return
res
;
return
res
;
...
@@ -419,7 +425,7 @@ public abstract class AbstractJdbcDriver extends AbstractDriver {
...
@@ -419,7 +425,7 @@ public abstract class AbstractJdbcDriver extends AbstractDriver {
ResultSet
results
=
null
;
ResultSet
results
=
null
;
int
count
=
0
;
int
count
=
0
;
try
{
try
{
preparedStatement
=
conn
.
prepareStatement
(
sql
);
preparedStatement
=
conn
.
get
().
prepareStatement
(
sql
);
results
=
preparedStatement
.
executeQuery
();
results
=
preparedStatement
.
executeQuery
();
if
(
Asserts
.
isNull
(
results
))
{
if
(
Asserts
.
isNull
(
results
))
{
result
.
setSuccess
(
true
);
result
.
setSuccess
(
true
);
...
...
dlink-metadata/dlink-metadata-base/src/main/java/com/dlink/metadata/driver/Driver.java
View file @
d0146a4d
...
@@ -28,6 +28,7 @@ import com.dlink.model.Schema;
...
@@ -28,6 +28,7 @@ import com.dlink.model.Schema;
import
com.dlink.model.Table
;
import
com.dlink.model.Table
;
import
com.dlink.result.SqlExplainResult
;
import
com.dlink.result.SqlExplainResult
;
import
javax.sql.DataSource
;
import
java.util.List
;
import
java.util.List
;
import
java.util.Map
;
import
java.util.Map
;
import
java.util.Optional
;
import
java.util.Optional
;
...
@@ -55,10 +56,11 @@ public interface Driver {
...
@@ -55,10 +56,11 @@ public interface Driver {
static
Driver
build
(
DriverConfig
config
)
{
static
Driver
build
(
DriverConfig
config
)
{
String
key
=
config
.
getName
();
String
key
=
config
.
getName
();
if
(
DriverPool
.
exist
(
key
))
{
if
(
DriverPool
.
exist
(
key
))
{
Driver
driver
=
DriverPool
.
get
(
key
);
return
getHealthDriver
(
key
);
if
(
driver
.
isHealth
())
{
return
driver
;
}
}
synchronized
(
Driver
.
class
)
{
if
(
DriverPool
.
exist
(
key
))
{
return
getHealthDriver
(
key
);
}
}
Optional
<
Driver
>
optionalDriver
=
Driver
.
get
(
config
);
Optional
<
Driver
>
optionalDriver
=
Driver
.
get
(
config
);
if
(!
optionalDriver
.
isPresent
())
{
if
(!
optionalDriver
.
isPresent
())
{
...
@@ -68,6 +70,17 @@ public interface Driver {
...
@@ -68,6 +70,17 @@ public interface Driver {
DriverPool
.
push
(
key
,
driver
);
DriverPool
.
push
(
key
,
driver
);
return
driver
;
return
driver
;
}
}
}
static
Driver
getHealthDriver
(
String
key
)
{
Driver
driver
=
DriverPool
.
get
(
key
);
if
(
driver
.
isHealth
())
{
return
driver
;
}
else
{
return
driver
.
connect
();
}
}
Driver
setDriverConfig
(
DriverConfig
config
);
Driver
setDriverConfig
(
DriverConfig
config
);
...
...
dlink-metadata/dlink-metadata-clickhouse/src/main/java/com/dlink/metadata/driver/ClickHouseDriver.java
View file @
d0146a4d
...
@@ -112,7 +112,7 @@ public class ClickHouseDriver extends AbstractJdbcDriver {
...
@@ -112,7 +112,7 @@ public class ClickHouseDriver extends AbstractJdbcDriver {
}
}
continue
;
continue
;
}
}
preparedStatement
=
conn
.
prepareStatement
(
"explain "
+
current
);
preparedStatement
=
conn
.
get
()
.
prepareStatement
(
"explain "
+
current
);
results
=
preparedStatement
.
executeQuery
();
results
=
preparedStatement
.
executeQuery
();
while
(
results
.
next
())
{
while
(
results
.
next
())
{
explain
.
append
(
getTypeConvert
().
convertValue
(
results
,
"explain"
,
"string"
)
+
"\r\n"
);
explain
.
append
(
getTypeConvert
().
convertValue
(
results
,
"explain"
,
"string"
)
+
"\r\n"
);
...
...
dlink-metadata/dlink-metadata-hive/src/main/java/com/dlink/metadata/driver/HiveDriver.java
View file @
d0146a4d
...
@@ -106,7 +106,7 @@ public class HiveDriver extends AbstractJdbcDriver implements Driver {
...
@@ -106,7 +106,7 @@ public class HiveDriver extends AbstractJdbcDriver implements Driver {
String
sql
=
dbQuery
.
tablesSql
(
schemaName
);
String
sql
=
dbQuery
.
tablesSql
(
schemaName
);
try
{
try
{
execute
(
String
.
format
(
HiveConstant
.
USE_DB
,
schemaName
));
execute
(
String
.
format
(
HiveConstant
.
USE_DB
,
schemaName
));
preparedStatement
=
conn
.
prepareStatement
(
sql
);
preparedStatement
=
conn
.
get
().
prepareStatement
(
sql
);
results
=
preparedStatement
.
executeQuery
();
results
=
preparedStatement
.
executeQuery
();
ResultSetMetaData
metaData
=
results
.
getMetaData
();
ResultSetMetaData
metaData
=
results
.
getMetaData
();
List
<
String
>
columnList
=
new
ArrayList
<>();
List
<
String
>
columnList
=
new
ArrayList
<>();
...
@@ -155,7 +155,7 @@ public class HiveDriver extends AbstractJdbcDriver implements Driver {
...
@@ -155,7 +155,7 @@ public class HiveDriver extends AbstractJdbcDriver implements Driver {
ResultSet
results
=
null
;
ResultSet
results
=
null
;
String
schemasSql
=
getDBQuery
().
schemaAllSql
();
String
schemasSql
=
getDBQuery
().
schemaAllSql
();
try
{
try
{
preparedStatement
=
conn
.
prepareStatement
(
schemasSql
);
preparedStatement
=
conn
.
get
().
prepareStatement
(
schemasSql
);
results
=
preparedStatement
.
executeQuery
();
results
=
preparedStatement
.
executeQuery
();
while
(
results
.
next
())
{
while
(
results
.
next
())
{
String
schemaName
=
results
.
getString
(
getDBQuery
().
schemaName
());
String
schemaName
=
results
.
getString
(
getDBQuery
().
schemaName
());
...
@@ -183,7 +183,7 @@ public class HiveDriver extends AbstractJdbcDriver implements Driver {
...
@@ -183,7 +183,7 @@ public class HiveDriver extends AbstractJdbcDriver implements Driver {
IDBQuery
dbQuery
=
getDBQuery
();
IDBQuery
dbQuery
=
getDBQuery
();
String
tableFieldsSql
=
dbQuery
.
columnsSql
(
schemaName
,
tableName
);
String
tableFieldsSql
=
dbQuery
.
columnsSql
(
schemaName
,
tableName
);
try
{
try
{
preparedStatement
=
conn
.
prepareStatement
(
tableFieldsSql
);
preparedStatement
=
conn
.
get
().
prepareStatement
(
tableFieldsSql
);
results
=
preparedStatement
.
executeQuery
();
results
=
preparedStatement
.
executeQuery
();
ResultSetMetaData
metaData
=
results
.
getMetaData
();
ResultSetMetaData
metaData
=
results
.
getMetaData
();
List
<
String
>
columnList
=
new
ArrayList
<>();
List
<
String
>
columnList
=
new
ArrayList
<>();
...
@@ -227,7 +227,7 @@ public class HiveDriver extends AbstractJdbcDriver implements Driver {
...
@@ -227,7 +227,7 @@ public class HiveDriver extends AbstractJdbcDriver implements Driver {
ResultSet
results
=
null
;
ResultSet
results
=
null
;
String
createTableSql
=
getDBQuery
().
createTableSql
(
table
.
getSchema
(),
table
.
getName
());
String
createTableSql
=
getDBQuery
().
createTableSql
(
table
.
getSchema
(),
table
.
getName
());
try
{
try
{
preparedStatement
=
conn
.
prepareStatement
(
createTableSql
);
preparedStatement
=
conn
.
get
().
prepareStatement
(
createTableSql
);
results
=
preparedStatement
.
executeQuery
();
results
=
preparedStatement
.
executeQuery
();
while
(
results
.
next
())
{
while
(
results
.
next
())
{
createTable
.
append
(
results
.
getString
(
getDBQuery
().
createTableName
())).
append
(
"\n"
);
createTable
.
append
(
results
.
getString
(
getDBQuery
().
createTableName
())).
append
(
"\n"
);
...
@@ -246,7 +246,7 @@ public class HiveDriver extends AbstractJdbcDriver implements Driver {
...
@@ -246,7 +246,7 @@ public class HiveDriver extends AbstractJdbcDriver implements Driver {
Asserts
.
checkNullString
(
sql
,
"Sql 语句为空"
);
Asserts
.
checkNullString
(
sql
,
"Sql 语句为空"
);
String
querySQL
=
sql
.
trim
().
replaceAll
(
";$"
,
""
);
String
querySQL
=
sql
.
trim
().
replaceAll
(
";$"
,
""
);
int
res
=
0
;
int
res
=
0
;
try
(
Statement
statement
=
conn
.
createStatement
())
{
try
(
Statement
statement
=
conn
.
get
().
createStatement
())
{
res
=
statement
.
executeUpdate
(
querySQL
);
res
=
statement
.
executeUpdate
(
querySQL
);
}
}
return
res
;
return
res
;
...
@@ -266,7 +266,7 @@ public class HiveDriver extends AbstractJdbcDriver implements Driver {
...
@@ -266,7 +266,7 @@ public class HiveDriver extends AbstractJdbcDriver implements Driver {
int
count
=
0
;
int
count
=
0
;
try
{
try
{
String
querySQL
=
sql
.
trim
().
replaceAll
(
";$"
,
""
);
String
querySQL
=
sql
.
trim
().
replaceAll
(
";$"
,
""
);
preparedStatement
=
conn
.
prepareStatement
(
querySQL
);
preparedStatement
=
conn
.
get
().
prepareStatement
(
querySQL
);
results
=
preparedStatement
.
executeQuery
();
results
=
preparedStatement
.
executeQuery
();
if
(
Asserts
.
isNull
(
results
))
{
if
(
Asserts
.
isNull
(
results
))
{
result
.
setSuccess
(
true
);
result
.
setSuccess
(
true
);
...
...
dlink-metadata/dlink-metadata-phoenix/src/main/java/com/dlink/metadata/driver/PhoenixDriver.java
View file @
d0146a4d
...
@@ -30,6 +30,8 @@ import com.dlink.model.Column;
...
@@ -30,6 +30,8 @@ import com.dlink.model.Column;
import
com.dlink.model.Table
;
import
com.dlink.model.Table
;
import
org.apache.commons.lang3.StringUtils
;
import
org.apache.commons.lang3.StringUtils
;
import
javax.sql.DataSource
;
import
java.sql.Connection
;
import
java.sql.DriverManager
;
import
java.sql.DriverManager
;
import
java.sql.SQLException
;
import
java.sql.SQLException
;
import
java.util.List
;
import
java.util.List
;
...
@@ -91,9 +93,10 @@ public class PhoenixDriver extends AbstractJdbcDriver {
...
@@ -91,9 +93,10 @@ public class PhoenixDriver extends AbstractJdbcDriver {
Properties
properties
=
new
Properties
();
Properties
properties
=
new
Properties
();
properties
.
put
(
"phoenix.schema.isNamespaceMappingEnabled"
,
"true"
);
properties
.
put
(
"phoenix.schema.isNamespaceMappingEnabled"
,
"true"
);
properties
.
put
(
"phoenix.schema.mapSystemTablesToNamespac"
,
"true"
);
properties
.
put
(
"phoenix.schema.mapSystemTablesToNamespac"
,
"true"
);
conn
=
DriverManager
.
getConnection
(
config
.
getUrl
(),
properties
);
Connection
connection
=
DriverManager
.
getConnection
(
config
.
getUrl
(),
properties
);
conn
.
set
(
connection
);
//设置为自动提交,否则upsert语句不生效
//设置为自动提交,否则upsert语句不生效
conn
.
setAutoCommit
(
true
);
conn
ection
.
setAutoCommit
(
true
);
}
catch
(
ClassNotFoundException
|
SQLException
e
)
{
}
catch
(
ClassNotFoundException
|
SQLException
e
)
{
throw
new
RuntimeException
(
e
);
throw
new
RuntimeException
(
e
);
}
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment