怎样用Java实现将在数据库中查询到的数据显示在表格中

怎样用Java实现将在数据库中查询到的数据显示在表格中,第1张

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);

}

}

sql语句要快1不必要的列就不用查出来;2作为查询的条件列设索引;3如果查询的表数据大于500万条数据,表创建之初就应该建立表分区,依据分表去查;

最最重要的是传输给前台页面的数据量尽量简化减少传输量,比如时间数据最好不传,自己规定个顺序,依据顺序前台生成对应的时间;非要传可转为毫秒数去掉最后四个零(依据实际情况而定,因为时间只要求精确到分),用[]不用{}(key就不用传了,根据商量好的下标对应提取)

首先建立DB连接Connection conn;

之后定义一个sql语句的字符串(里面是你要的sql的语句)

定义一个结果集ResultSet rs ;

执行sql语句

将结果集中对应属性到你定义好的数组就好了

1

把你要查询显示的数据,封装成一个对象。

2

把你查询出的数据放到这个对象的List中。

3

根据你表格的抬头,循环这个List,把你要填的值填到表格中。

以上就是关于怎样用Java实现将在数据库中查询到的数据显示在表格中全部的内容,包括:怎样用Java实现将在数据库中查询到的数据显示在表格中、java里当数据库里的数据量很大的时候、要一次性查询出来、并且展示出来、应该怎样查询、效率更高、java中如何把数据库某个表的数据查出来,装在数组当中有具体例子最好等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

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

原文地址: http://outofmemory.cn/sjk/10193177.html

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

发表评论

登录后才能评论

评论列表(0条)

保存