可視化Swing中JTable控件綁定SQL數(shù)據(jù)源的兩種方法深入解析
在 MyEclipse 的可視化 Swing 中,有 JTable 控件。
JTable 用來顯示和編輯常規(guī)二維單元表。
那么,如何將 數(shù)據(jù)庫SQL中的數(shù)據(jù)綁定至JTable中呢?
在這里,提供兩種方法。
JTable的構造方法
通過查閱Java的API,可以可以得到JTable的兩個重要的構造方法:
JTable(Object[][] rowData, Object[] columnNames)
構造一個 JTable 來顯示二維數(shù)組 rowData 中的值,其列名稱為 columnNames。
JTable(TableModel dm)
構造一個 JTable,使用數(shù)據(jù)模型 dm、默認的列模型和默認的選擇模型對其進行初始化。
以下,我們就通過這兩個構造方法來將JTable綁定到SQL數(shù)據(jù)庫。
必要的準備工作
一、有一個可供綁定的數(shù)據(jù)庫。
二、在可視化Swing中拖拉進來一個Jtable控件。
方法一:通過二維數(shù)組綁定
該方法用到的構造方法為:
JTable(Object[][] rowData, Object[] columnNames)
構造一個 JTable 來顯示二維數(shù)組 rowData 中的值,其列名稱為 columnNames。
構建二維數(shù)組rowData
通過上節(jié)博文“預編譯”的學習,我們已經能夠將SQL數(shù)據(jù)庫讀取至ResultSet 中。
《JDBC之PreparedStatement類中預編譯的綜合應用解析》
回顧如下:
/** 查詢并返回記錄集 */
public ResultSet getResultSet(String sql, Object[] objArr){
getConnection();
try {
pStatement = connection.prepareStatement(sql, ResultSet.TYPE_SCROLL_INSENSITIVE, ResultSet.CONCUR_READ_ONLY);
if(objArr!=null && objArr.length>0) {
for (int i = 0; i < objArr.length; i++) {
pStatement.setObject(i+1, objArr[i]);
}
}
rSet = pStatement.executeQuery();
//list = resultSetToList(rs);
} catch (SQLException e) {
e.printStackTrace();
} finally {
//close();
}
return rSet;
}
【注】只是與上節(jié)博客的方法名不同而已。。
現(xiàn)在,我們?yōu)榱藢esultSet 轉化為二維數(shù)組,寫如下方法:
/** 把結果集轉成Object[][] */
public Object[][] resultSetToObjectArray(ResultSet rs) {
Object[][] data = null;
try {
rs.last();
int rows = rs.getRow();
data = new Object[rows][];
ResultSetMetaData md = rs.getMetaData();//獲取記錄集的元數(shù)據(jù)
int columnCount = md.getColumnCount();//列數(shù)
rs.first();
int k = 0;
while(rs.next()) {
System.out.println("i"+k);
Object[] row = new Object[columnCount];
for(int i=0; i<columnCount; i++) {
row[i] = rs.getObject(i+1).toString();
}
data[k] = row;
k++;
}
} catch (Exception e) {
}
return data;
}
并將這兩個方法存至文件UserDAO.java中。
在Swing所在的Java文件中先實例化UserDAO:
UserDAO userDAO = new UserDAO();
即可將SQL數(shù)據(jù)轉化為二維數(shù)組:
Object[][] dataObjects = userDAO.resultSetToObjectArray(userDAO.getResultSet(
"select id,username,password from t_userr", null));
構建列名稱 columnNames
這個比較簡單,只需要將列名稱寫入String數(shù)組即可。
String[] tableStrings = { "id", "username", "password" };
構建JTable的Model:
jTable1.setModel(new DefaultTableModel(dataObjects, tableStrings));
整體代碼視圖:
整體代碼視圖:

最終JTable效果圖:

方法二:通過Model綁定該方法用到的構造方法為:
JTable(TableModel dm)
構造一個 JTable,使用數(shù)據(jù)模型 dm、默認的列模型和默認的選擇模型對其進行初始化。
進入 JTable 控件的控制面板,點擊model。

選擇Model來自代碼。

填寫 model 的方法路徑:包名.Java文件名.方法名。
為了調用方便,建議將方法設置為靜態(tài)方法。

在剛剛設置的路徑下寫入Model的方法,注意其返回類型為TableModel。
方法的寫法與上面的大同小異,不再贅述。
public static TableModel Member() {
String[][] playerInfo = new String[80][8];
BaseDAO bDao = new BaseDAO();
String sql = "select id,realName,username,sex,phone,email,vocation,city from jdbctest";
String[] ss = {};
ArrayList<HashMap<Object, Object>> list = bDao.Query(sql, ss);
// bDao.AllArray(list);
int i = 0, j = 0;
for (HashMap<Object, Object> maps : list) {
Set<Object> keysObjects = maps.keySet();
for (Object kObject : keysObjects) {
playerInfo[i][j] = maps.get(kObject).toString();
j++;
}
i++;
j = 0;
}
String[] Names = { "id", "username", "sex", "phone","vocation","email","realName", "city" };
DefaultTableModel dModel = new DefaultTableModel(playerInfo, Names);
return (TableModel)dModel;
}
JTable 效果

- Java Swing中的表格(JTable)和樹(JTree)組件使用實例
- Java Swing實現(xiàn)JTable檢測單元格數(shù)據(jù)變更事件的方法示例
- Java Swing中JTable渲染器與編輯器用法示例
- Jtable和JTree的寫法示例代碼
- jtable列中自定義button示例代碼
- 解決JTable排序問題的方法詳解
- 基于JTable的列寬與內容自適應的實現(xiàn)方法
- Java Swing中的文本框(JTextField)與文本區(qū)(JTextArea)使用實例
- Java Swing中的下拉式菜單(menu)、彈出式菜單(JPopupMenu)、選項卡窗體(JTabbedPane)組件使用案例
- java swing中實現(xiàn)拖拽功能示例
- Java Swing組件編程之JTable表格用法實例詳解
相關文章
Spring Boot中l(wèi)ombok的安裝與使用詳解
這篇文章主要給大家介紹了關于Spring Boot中l(wèi)ombok安裝與使用的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧。2017-09-09
springboot使用spring-data-jpa操作MySQL數(shù)據(jù)庫
這篇文章主要介紹了springboot使用spring-data-jpa操作MySQL數(shù)據(jù)庫,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-07-07
利用Spring JPA中的@Version注解實現(xiàn)樂觀鎖
樂觀鎖是數(shù)據(jù)庫和應用程序中使用的一種并發(fā)控制策略,用于在多個事務嘗試更新單個記錄時確保數(shù)據(jù)完整性,Java Persistence API (JPA) 提供了一種借助@Version注解在 Java 應用程序中實現(xiàn)樂觀鎖的機制,文中有詳細的代碼示例供大家參考,需要的朋友可以參考下2023-11-11
SpringCloud Gateway自定義filter獲取body中的數(shù)據(jù)為空的問題
這篇文章主要介紹了SpringCloud Gateway自定義filter獲取body中的數(shù)據(jù)為空,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-10-10
Java常用鎖synchronized和ReentrantLock的區(qū)別
這篇文章主要介紹了Java常用鎖synchronized和ReentrantLock的區(qū)別,二者的功效都是相同的,但又有很多不同點,下面我們就進入文章了解具體的相關內容吧。需要的小伙伴也可以參考一下2022-05-05

