使用原生JDBC動(dòng)態(tài)解析并獲取表格列名和數(shù)據(jù)的方法
應(yīng)用場(chǎng)景
查詢某張表,對(duì)于返回的執(zhí)行結(jié)果,咱們并不需要知道他有哪些字段,字段名叫啥,直接通過(guò)原生JDBC動(dòng)態(tài)的獲取列名以及對(duì)應(yīng)的數(shù)據(jù)。
其實(shí)就有點(diǎn)像遍歷map集合,并不需要知道key叫啥,一樣可以遍歷出來(lái):
Map<String,Object> map = Maps.newHashMap(); for (Map.Entry<String, Object> entry : map.entrySet()) { System.out.println(entry.getKey() + " : " + entry.getValue()); }
目標(biāo)
將數(shù)據(jù)庫(kù)查詢出來(lái)的結(jié)果,存放到一個(gè)List<Map<String, Object>>集合中,方便后續(xù)批量將該集合的數(shù)據(jù)插入到其他地方
整干貨
private List<Map<String, Object>> executeQuery(String sqlStr,String url,String username,String password) { Connection connection = DriverManager.getConnection(url, username, password); Statement statement = null; ResultSet resultSet = null; List<Map<String, Object>> resultList = new ArrayList<Map<String, Object>>(); try { statement = connection.createStatement(); resultSet = statement.executeQuery(sqlStr); final ResultSetMetaData rsmd = resultSet.getMetaData(); final String[] columnName = new String[rsmd.getColumnCount()]; for (int i = 1; i <= rsmd.getColumnCount(); ++i) { columnName[i - 1] = rsmd.getColumnLabel(i); } while (resultSet.next()) { LinkedHashMap<String, Object> map = new LinkedHashMap<String, Object>(); for (int j = 1; j <= rsmd.getColumnCount(); ++j) { if (resultSet.getObject(j) != null && !resultSet.getObject(j).equals("")) { String columnData = resultSet.getObject(j).toString().trim(); map.put(columnName[j - 1], columnData); } else { map.put(columnName[j - 1], ""); } } resultList.add(map); } } catch (SQLException e) { logger.error("SQL語(yǔ)句執(zhí)行失敗",e); }finally { if( null != resultSet ) { resultSet.close(); } if( null != statement ) { statement.close(); } if( null != connection ) { connection .close(); } } return resultList; }
到此這篇關(guān)于使用原生JDBC動(dòng)態(tài)解析并獲取表格列名和數(shù)據(jù)的文章就介紹到這了,更多相關(guān)JDBC獲取表格列名和數(shù)據(jù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
SpringBoot+Vue靜態(tài)資源刷新后無(wú)法訪問(wèn)的問(wèn)題解決方案
這篇文章主要介紹了SpringBoot+Vue靜態(tài)資源刷新后無(wú)法訪問(wèn)的問(wèn)題解決方案,文中通過(guò)代碼示例和圖文講解的非常詳細(xì),對(duì)大家解決問(wèn)題有一定的幫助,需要的朋友可以參考下2024-05-05Java使用鎖解決銀行取錢(qián)問(wèn)題實(shí)例分析
這篇文章主要介紹了Java使用鎖解決銀行取錢(qián)問(wèn)題,結(jié)合實(shí)例形式分析了java線程同步與鎖機(jī)制相關(guān)原理及操作注意事項(xiàng),需要的朋友可以參考下2019-08-08k8s部署springboot實(shí)現(xiàn)前后端分離項(xiàng)目
本文主要介紹了k8s部署springboot實(shí)現(xiàn)前后端分離項(xiàng)目,主要包括配置文件、鏡像構(gòu)建和容器編排等方面,具有一定的參考價(jià)值,感興趣的可以了解一下2024-01-01如何利用postman完成JSON串的發(fā)送功能(springboot)
這篇文章主要介紹了如何利用postman完成JSON串的發(fā)送功能(springboot),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-07-07IntelliJ IDEA 2020 安裝和常用配置(推薦)
這篇文章主要介紹了IntelliJ IDEA 2020 安裝和常用配置(推薦),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-08-08spring boot自定義log4j2日志文件的實(shí)例講解
下面小編就為大家分享一篇spring boot自定義log4j2日志文件的實(shí)例講解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2017-11-11