springboot引入druid解析sql的過(guò)程
一、前言
在開(kāi)發(fā)中,有時(shí)我們可能會(huì)需要獲取SQL中的表名,那么因?yàn)椴煌臄?shù)據(jù)源類型SQL會(huì)存在部分差異,那么我們就可以使用alibaba 的druid包實(shí)現(xiàn)不同的數(shù)據(jù)源類型的sql解析。
二、引入相關(guān)maven依賴
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid</artifactId>
<version>1.2.8</version>
</dependency>三、通過(guò)工具類SqlUtils實(shí)現(xiàn)對(duì)SQL的解析。
public class QualitySqlUtils {
/**
* 根據(jù)sql及數(shù)據(jù)源類型獲取表名
*/
public static List<String> getSelectSqlTable(String sql, String dbType) {
List<String> tableList = new ArrayList<>();
List<SQLStatement> stmtList = SQLUtils.parseStatements(sql, dbType);
SchemaStatVisitor visitor;
for (SQLStatement sqlStatement : stmtList) {
if (DbType.mysql.name().equalsIgnoreCase(dbType)) {
visitor = new MySqlSchemaStatVisitor();
} else if (DbType.hive.name().equalsIgnoreCase(dbType)) {
visitor = new HiveSchemaStatVisitor();
} else if (DbType.postgresql.name().equalsIgnoreCase(dbType)) {
visitor = new PGSchemaStatVisitor();
} else if (DbType.oracle.name().equalsIgnoreCase(dbType)) {
visitor = new OracleSchemaStatVisitor();
} else {
visitor = new SchemaStatVisitor(DbType.of(dbType));
}
sqlStatement.accept(visitor);
Map<TableStat.Name, TableStat> tables = visitor.getTables();
for (Map.Entry<TableStat.Name, TableStat> entry: tables.entrySet()){
String value = entry.getValue().toString();
if (StringUtils.isNotBlank(value)) {
tableList.add(entry.getKey().getName());
}
}
}
return tableList;
}
/**
* 根據(jù)sql獲取查詢的字段
*/
public static Map<String, String> getSelectSqlColumn(String sql, String dbType) {
Map<String, String> columnMap = new HashMap<>();
List<SQLStatement> stmtList = SQLUtils.parseStatements(sql, dbType);
for (int i = 0; i < stmtList.size(); i++) {
SQLStatement stmt = stmtList.get(i);
if (stmt instanceof SQLSelectStatement) {
SQLSelectStatement sqlSelectStatement = (SQLSelectStatement) stmt;
SQLSelect select = sqlSelectStatement.getSelect();
SQLSelectQueryBlock query = (SQLSelectQueryBlock) select.getQuery();
List<SQLSelectItem> selectList = query.getSelectList();
selectList.forEach(item->{
columnMap.put(item.getExpr().toString(), item.getAlias());
});
}
}
return columnMap;
}
}三、測(cè)試結(jié)果
public class testDemo{
public static void main(String[] args) {
String sql = "select t.* from table1 as t left join table2 t2 on t.id = t2.id";
List<String> tableList =getSelectSqlTable(sql, "mysql");
System.out.println("獲取到的表名: "+tableList);
}
}運(yùn)行結(jié)果如下:

到此這篇關(guān)于springboot引入druid解析sql的文章就介紹到這了,更多相關(guān)springboot引入druid內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
如何使用Spring?Boot設(shè)置上傳文件大小限制
上傳文件是互聯(lián)網(wǎng)中常應(yīng)用的場(chǎng)景之一,最典型的情況就是上傳頭像等,下面這篇文章主要給大家介紹了關(guān)于如何使用Spring?Boot設(shè)置上傳文件大小限制的相關(guān)資料,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-01-01
Java中的system.getProperty()的作用及使用方法
System.getProperty()?方法用于獲取系統(tǒng)屬性的值,該方法接受一個(gè)字符串參數(shù),表示要獲取的系統(tǒng)屬性的名稱,返回值為字符串類型,表示該屬性的值,接下來(lái)通過(guò)本文給大家介紹Java中的system.getProperty()的作用及使用方法,感興趣的朋友跟隨小編一起看看吧2023-05-05
Java版超大整數(shù)階乘算法代碼詳解-10,0000級(jí)
這篇文章主要介紹了Java版超大整數(shù)階乘算法代碼詳解-10,0000級(jí),具有一定借鑒價(jià)值,需要的朋友可以參考下2018-01-01
java理論基礎(chǔ)Stream?reduce實(shí)現(xiàn)集合元素歸約
這篇文章主要為大家介紹了java理論基礎(chǔ)Stream?reduce實(shí)現(xiàn)集合元素歸約示例詳解有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步2022-03-03
SpringBoot項(xiàng)目啟動(dòng)后立馬自動(dòng)關(guān)閉的解決方案
這篇文章主要介紹了SpringBoot項(xiàng)目啟動(dòng)后立馬自動(dòng)關(guān)閉的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-03-03
java實(shí)現(xiàn)輕輕松松控制臺(tái)斗地主的示例代碼
這篇文章主要介紹了java實(shí)現(xiàn)輕輕松松控制臺(tái)斗地主,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-04-04
springboot?vue接口測(cè)試前后端實(shí)現(xiàn)模塊樹(shù)列表功能
這篇文章主要為大家介紹了springboot?vue接口測(cè)試前后端實(shí)現(xiàn)模塊樹(shù)列表功能,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-05-05
java實(shí)現(xiàn)讀取jar包中配置文件的幾種方式
本文主要介紹了java實(shí)現(xiàn)讀取jar包中配置文件的幾種方式,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-06-06
java如何把逗號(hào)分隔的String字符串轉(zhuǎn)int集合
這篇文章主要介紹了java實(shí)現(xiàn)把逗號(hào)分隔的String字符串轉(zhuǎn)int集合,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-06-06

