gpt4 book ai didi

java - 如何在 JTable 中显示空值?

转载 作者:行者123 更新时间:2023-12-02 01:45:02 25 4
gpt4 key购买 nike

我有一个从数据库中获取数据的表。但在我的数据库中,有时某些字段可能为空值,而 JTable 不显示这些空值。我想将表中的空值显示为 NA。我怎样才能做到这一点?

public void displayMovieTable(){
try {

PreparedStatement pr = conn.prepareStatement("select * from movie");
ResultSet s = pr.executeQuery();
movieTable.setModel(DbUtils.resultSetToTableModel(s));
pr.close();

} catch (SQLException ex) {
Logger.getLogger(MainFrame.class.getName()).log(Level.SEVERE, null, ex);
}
}

最佳答案

最简单的可能是封装 JDBC 的特定表模型。

但是更改显示是一般方法:

TableCellRenderer old = movieTable.getDefaultRenderer(); // I.o. super?
movieTable.setDefaultRenderer(String.class, new DefaultTableCellRenderer() {
@Override
public Component getTableCellRendererComponent(JTable table,
Object value,
boolean isSelected,
boolean hasFocus,
int row,
int column) {
boolean notAvailable = value == null;
if (notAvailable) {
value = "N/A";
}
Component compon = super.getTableCellRendererComponent(table,
value,
isSelected,
hasFocus,
row,
column);
if (notAvailable) {
compon.setBackground(Color.GRAY);
}
return compon;
}
});

这里的问题是可能有多个渲染器。

关于java - 如何在 JTable 中显示空值?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53818080/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com