java 怎么把数据库中符合条件的数据一条条的添加到list里面

java 怎么把数据库中符合条件的数据一条条的添加到list里面,第1张

Result rs = connexecuteQuery();

while(rsnext()){

listadd(rsgetString("columnName"));

}

-- 定义函数

create function func()

returns @tbl table (c_au_id varchar(20), c_au_lname varchar(50))

begin

insert into @tbl select au_id, au_lname from dboauthors

return ;

end

-- 查询语句

select from func()

这个要从头说起就复杂了。我简单说一下吧。

首先,要把数据从库中取出来,假设你已经会了。

其次,创建一个表格模型,

DefaultTableModel model=new DefaultTableModel();

//创建表头

modelsetColumnIdentifiers(new Object[]{"日期/时间"," *** 作工","产品型号","数量"});

再次,添加数据

while(resultsnext())

{

String dt=resultsgetString("dt");

String name=resultsgetString("name");

String pname=resultsgetString("product");

int i=resultsgetInt("num");

//把以上数据添加到表格模型的一行中

modeladdRow(new Object[]{dt,name,pname,i});

}

最后,用模型生成表格

JTable table=new JTable(model);

当然,还有一些其它的 *** 作,比如把表格显示出来,表格的字体、行高等设置等等,不再一一赘述。

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

}

}

以上就是关于java 怎么把数据库中符合条件的数据一条条的添加到list里面全部的内容,包括:java 怎么把数据库中符合条件的数据一条条的添加到list里面、java怎样把数据库数据显示在table控件中、怎样用Java实现将在数据库中查询到的数据显示在表格中等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

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

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

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

发表评论

登录后才能评论

评论列表(0条)

保存