java 将数据库表连接到 JTable 总是报错

java 将数据库表连接到 JTable 总是报错,第1张

ResultSet 的 last()方法是将游标指向最后一行,next()是指从当前行移至下一行,你这个地方有问题,当然这和报错应该没什么关系,呵呵,我不知道你那个查询语句为什么会报错,是不是你数据库里这张表不存在啊。。。

假设你的JTable名为 jTable

1, new 一个DefaultTableModel 假设名字取为 myTModel

2,jTablesetModel(myTModel);

3, 从数据库中读出column names 存在 String[] colNames;

(用ResultSetMetaData读)

3, myTModeladdColumn(colNames) 在表中添加列名

4,逐行读出表内容,存入一个Vector中 假设这个Vector名为 newRow

5,myTModeladdRow(newRow)

回答完毕 祝你顺利

JTable的有一个方法是getTableModel()返回提供此 JTable 所显示数据的 TableModel

TableModel是一个接口,实际上返回的是DefaultTableModel类,它实现了TableModel接口。这个类中有一个方法是void addRow(Object[] rowData)。它就是将一行插入到JTable中。

不过JTable的setValueAt方法应该就可以实现。

楼主可以定义个一个线程类来完成。

比如你需要插入100行数据,可以在线程的run方法中写一个循环,在循环中写两行代码,一行是setValueAt,一行是刷新JTable,然后再让线程睡眠,这样一行一行的显示的效果就可以出来了!

或者楼主可以用进度条来打发等待的时间,就像打开netbeans的那个进度条一样,这个可以用JProgressBar类。楼主可以去查看一下源代码。如果楼主还是没有头绪,我干脆就写个例子得了!

关于组件的添加或者类似设置窗口的大小,布局管理器等我就不做解释了!

import javaxswing;

import javaawtevent;

import javaawt;

import javaxswingtable;

public class Test extends JFrame implements ActionListener

{

private JButton button1;

private JButton button2;

private JButton button3;

private DefaultTableModel model;

private JTable table;

private JProgressBar bar;

private JScrollPane scrollpane;

private JPanel panel;

public Test()

{

button1=new JButton("演示1");

button2=new JButton("演示2");

button3=new JButton("清空");

panel=new JPanel();

bar=new JProgressBar(0,100);

String[] colnames={"数据一","数据二"};

model=new DefaultTableModel(colnames,100);

table=new JTable(model);

scrollpane=new JScrollPane(table);

panelsetLayout(new FlowLayout());

button1addActionListener(this);

button2addActionListener(this);

button3addActionListener(this);

paneladd(button1);

paneladd(button2);

paneladd(button3);

paneladd(bar);

thissetLayout(new GridLayout(2,1));

thissetSize(500,600);

thissetDefaultCloseOperation(JFrameEXIT_ON_CLOSE);

thisadd(scrollpane);

thisadd(panel);

}

public void actionPerformed(ActionEvent e)

{

String command=egetActionCommand();

if(commandequals("演示1"))

{

ShowModel show=new ShowModel(true);

Thread thread=new Thread(show);

threadstart();

}

else if(commandequals("演示2"))

{

ShowModel show=new ShowModel(false);

Thread thread=new Thread(show);

threadstart();

}

else

{

String[] colnames={"数据一","数据二"};

model=new DefaultTableModel(colnames,100);

tablesetModel(model);

}

}

private class ShowModel implements Runnable

{

private boolean type;//当type为true时,则说明是“演示1”的线程,false则相反

public ShowModel(boolean type)

{

thistype=type;

}

public void run()

{

if(type)//这个就是让线程睡眠,并且设置JTable的值

{

try{

for(int i=0;i<100;i++)

{

TestthistablesetValueAt(StringvalueOf(i),i,0);

TestthistablesetValueAt(StringvalueOf(i),i,1);

Threadsleep(100);

}

}catch(Exception e)

{

eprintStackTrace();

}

}

else//这个就是进度条的演示

{

try{

TestthistablesetVisible(false);

for(int i=0;i<100;i++)

{

TestthistablesetValueAt(StringvalueOf(i),i,0);

TestthistablesetValueAt(StringvalueOf(i),i,1);

TestthisbarsetValue(i+1);

TestthisbarsetString(StringvalueOf(i+1)+"%");

Threadsleep(40);

if(i==99)

{

TestthistablesetVisible(true);

JOptionPaneshowMessageDialog(Testthis,"OK");

TestthisbarsetValue(0);

}

}

}catch(Exception e)

{

eprintStackTrace();

}

}

}

}

public static void main(String[] args)

{

Test test=new Test();

testsetVisible(true);

}

}

JTable的单元格可以修改,而且可以监听单元格修改事件,实现TableModelListener的public

void

tableChanged(TableModelEvent

e)方法,监听到单元格修改后,在响应函数中把修改后的值传入数据库就ok了

以上就是关于java 将数据库表连接到 JTable 总是报错全部的内容,包括:java 将数据库表连接到 JTable 总是报错、java 中如何在JTABLE中显示连接数据库表中的数据、怎样用Java实现将在数据库中查询到的数据显示在表格中等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/sjk/9871599.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-02
下一篇2023-05-02

发表评论

登录后才能评论

评论列表(0条)

    保存