- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
这个类与我的数据库通信检索数据并将它们投影到 JTable。我使用了 DefaultTableModel 但列名不会出现。我在另一个类中实例化这个类,我通过 检索包含数据的表获取表格()
。
package jtable;
import javax.swing.*;
import javax.swing.table.*;
import java.sql.*;
public class ControlDatabase
{
private JTable table;
private Statement stmt;
private DefaultTableModel model;
private String all = "SELECT * FROM Players ORDER BY id ASC";
public ControlDatabase( )
{
String dbUsername = "root";
String dbPassword = "*****";
String dbHost = "localhost";
String dbPort = "3306";
String dbName = "oop_project_database";
String url = "jdbc:mysql://" + dbHost + ":" + dbPort + "/" + dbName;
try {
Connection con = DriverManager.getConnection(url, dbUsername, dbPassword);
model = new DefaultTableModel();
model.addColumn("Id");
model.addColumn("Onoma");
model.addColumn("Epwnimo");
model.addColumn("Age");
model.addColumn("Nickname");
table = new JTable(model);
stmt = con.createStatement();
updateStatement( all );
} catch (SQLException ex) {
ex.printStackTrace(System.out);
}
}
public void addStatement(String name,String surname,Integer age,String nickname )
{
String query = "INSERT INTO Players (name,surname,age,nickname) VALUES ('"
+ name +
"','"
+ surname +
"',"
+ age +
",'"
+ nickname +
"')";
try {
int x = stmt.executeUpdate( query );
if (x > 0) {
lastStatement(all);
// updateStatement(all , true );
}
} catch (SQLException e) {
e.printStackTrace();
}
}
public Boolean deleteStatement(String id , int row )
{
String query = "DELETE FROM Players WHERE id = " + id ;
try {
int x = stmt.executeUpdate( query );
if (x > 0) {
model.removeRow(row);
return true;
}
return false;
} catch (SQLException e) {
e.printStackTrace();
return false;
}
}
public void updateStatement(String query , Boolean flag )
{
try {
ResultSet rs = stmt.executeQuery( query );
while (rs.next()) {
int currentId = rs.getInt("id");
String currentName = rs.getString("name");
String currentSurname = rs.getString("surname");
int currentAge = rs.getInt("age");
String currentNick = rs.getString("nickname");
Object[] currentRow = { currentId ,currentName, currentSurname, currentAge, currentNick };
model.addRow(currentRow);
}
} catch (SQLException ex) {
ex.printStackTrace(System.out);
}
}
public void updateStatement(String query) {
updateStatement(query , false );
}
public void lastStatement(String query )
{
try {
ResultSet rs = stmt.executeQuery( query );
rs.last();
int currentId = rs.getInt("id");
String currentName = rs.getString("name");
String currentSurname = rs.getString("surname");
int currentAge = rs.getInt("age");
String currentNick = rs.getString("nickname");
Object[] currentRow = { currentId ,currentName, currentSurname, currentAge, currentNick };
model.addRow(currentRow);
} catch (SQLException ex) {
ex.printStackTrace(System.out);
}
}
public JTable getTable( ) {
return table;
}
}
主类
package jtable;
import javax.swing.*;
import java.awt.*;
import java.awt.event.*;
public class MainD extends JFrame{
private JPanel p;
//private JPanel pa;
private JScrollPane pa; //<-- change
private JSplitPane splitPane;
private JButton b,ba;
private JLabel ln,ls,la,lc;
private JTextField txs,txn,txa,txc;
private ControlDatabase data;
private JTable table;
public MainD()
{
super("Split");
p = new JPanel(new GridLayout(5,2));
//pa = new JPanel(new GridLayout(1,1));
pa = new JScrollPane( ); //<--
ln = new JLabel("Name");
txn = new JTextField();
ls = new JLabel("Surname");
txs = new JTextField();
la = new JLabel("Age");
txa = new JTextField();
ba = new JButton("Add");
lc = new JLabel("Nickname");
txc = new JTextField();
ba.addActionListener(new ActionListener() { //Add
public void actionPerformed(ActionEvent e){
String name = txn.getText();
String surname = txs.getText();
String sage = txa.getText();
String nickname = txc.getText();
if (!( name.isEmpty() || surname.isEmpty() || nickname.isEmpty() || sage.isEmpty() )) {
try {
Integer age = Integer.parseInt( sage );
data.addStatement(name,surname,age,nickname);
txn.setText("");
txs.setText("");
txa.setText("");
txc.setText("");
}catch(NumberFormatException ex){
System.out.println("Age must be an Integer");
}
}
else{
System.out.println("Empty Fields");
}
}
}
);
b = new JButton("Remove");
data = new ControlDatabase();
table = data.getTable();
pa.add(table);
b.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent e){
int row = table.getSelectedRow();
String value = String.valueOf( table.getValueAt( row ,0 ) );
data.deleteStatement( value , row );
}
}
);
p.add(ln);
p.add(txn);
p.add(ls);
p.add(txs);
p.add(la);
p.add(txa);
p.add(lc);
p.add(txc);
p.add(ba);
p.add(b);
splitPane = new JSplitPane(JSplitPane.HORIZONTAL_SPLIT, p, pa);
splitPane.setDividerLocation(280);
add(splitPane);
setBounds(200,200,800,400);
setDefaultCloseOperation(EXIT_ON_CLOSE);
setVisible(true);
}
public static void main(String[] args) {
new MainD();
}
}
最佳答案
您可能没有将表格放在 JScrollPane
中,这就是它不绘制标题的原因。或者调用getTableHeader()
单独添加。引用自 JTable
javadoc :
Note that if you wish to use a JTable in a standalone view (outside of a JScrollPane) and want the header displayed, you can get it using getTableHeader() and display it separately.
编辑:要将组件添加到 JScrollPane
,要么将组件提供给 JScrollPane
的构造函数,要么调用 JScrollPane.setViewportView(component)
关于java - 没有列名的 DefaultTableModel,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7944819/
我有一个 jTable,显示一个简单的两列 SQL 表的数据并允许用户维护该列表。这是我的第一个java程序。使其正常工作,以便用户可以编辑数据列表并按“保存”进行更新。我从这行代码获取 jTable
由于某种奇怪的原因,每次我在任何单元格中编辑数据并确认它时一旦我进入下一个,它就会从之前编辑的单元格复制数据 有什么想法吗? public class CheckoutTableModel exten
我有3个类(class) 首先从数据库获取数据 第二个为共同作品 其他用于展示表。 public class TableContent { private final Vector headers;
我的 DefaultTableModel 有问题,它不会向我显示表中的列,有一部分代码: JTable table = new JTable() { public boolean is
我有这个测试文件 text_file我的 TableView 是 enter image description here我想将每一行与每一列相匹配(第一行-第一列,第二行-第二列,等等。)错误在哪里
如何在 DefaultTableModel dtm = new DefaultTableModel(); 上添加标题和数据而不放置 new DefaultTableModel(在此内部)?我尝试使用
我的 Java GUI 中显示了一个表,用户可以通过单击“添加”按钮向其中添加行。添加到表格的行中的单元格默认都是可编辑的,用户可以根据需要选择每一行/单元格。 我现在想要添加从表中删除行的功能,但我
我有数据关系 Person-Attends-Course Person ------- id: integer primary key name: string prename: string age
我正在制作一个 GUI 简单的日历程序。我使用 DefaultTableModel 和 DefaultTableCellRenderer 显示日历的月 View 。我的日历设置为突出显示今天的日期。我
新数据输入数据库后,我的 JTable 没有刷新。我需要终止并再次执行才能看到结果。我包括了 DefaultTableModel 和 fireTableDataChanged。我还错过了什么?谢谢!
http://codepaste.net/ujhdq2 private Connection Econn; private DefaultTableModel examTable =
我使用 SwingWorker 根据数据库中的更改更改 DefaultTableModel。我的问题是:在 doInBackground() 中向 DefaultTableModel 添加 ListS
更新了问题,具体问题是数据没有显示,因为没有列: run: [java] Aug 04, 2014 8:17:00 PM net.bounceme.dur.client.gui.Applic
我一直在尝试将一些数据从 Editable JComboBox 发送到 JXTable。它的代码如下: private void selectTestActionPerformed(java.awt.
我有一个用 Object[][] 数组填充的 DefaultTableModel。 现在我想添加一个带有复选框的列并相应地执行操作。 当我将复选框添加到 Object[][] 数组并查看它时,我会显示
这个类与我的数据库通信检索数据并将它们投影到 JTable。我使用了 DefaultTableModel 但列名不会出现。我在另一个类中实例化这个类,我通过 检索包含数据的表获取表格()。 packa
我正在使用 Java Swingx 框架。我的 DefaultTableModel 对象中有 4 列。我只想显示其中 3 列。但是,我需要全部四个来进行计算。 实际数据模型 S.No. |身份证 |
我在 NetBeans 中使用 DefaultTableModel 来显示 MySQL 数据库中的记录。我的数据能够显示,但我想要的是在表格末尾显示一个复选框列。 我知道它需要被覆盖,但我不知道如何以
List myProducts = getMyProducts();//create an arraylist; Vector dataVector = new Vector(myProducts);
是的,我知道,这听起来很愚蠢。但在此之前,让我先说明一下我的问题。 我有一个带有大量 JTable 的 GUI。我有各种 DefaultTableModel,每个 JTable 一个。所以,1:1。对
我是一名优秀的程序员,十分优秀!