package com.applet.cat10;import java.awt.*;
import java.awt.event.*;
import java.applet.*;
import javax.swing.*;
import com.util.*;
import java.util.*;
import javax.swing.table.*;
import java.sql.*;/**
* Title: Cat工程
* Description: BCat
* Copyright: Copyright (c) 2001
* Company: smartcomm
* @author daniel
* @version 1.0
*/public class TestDatabase extends JApplet {
boolean isStandalone = false;
JButton jButton1 = new JButton(); 
Database db=new Database();
JTable table1 = new JTable();
JScrollPane scroll = new JScrollPane();
JTextField text1 = new JTextField();DefaultTableModel dtm; 
Vector vCdata=null; 
ResultSet rsRow=null; //**Construct the applet*/
public TestDatabase() {
}
/**Initialize the applet*/
public void init() {
try {
jbInit();
userInit(); 
}
catch(Exception e) {
e.printStackTrace();
}
}
/**Component initialization*/
private void jbInit() throws Exception {
jButton1.setText("jButton1");
jButton1.setBounds(new Rectangle(26, 225, 79, 29));
jButton1.addActionListener(new java.awt.event.ActionListener() {
public void actionPerformed(ActionEvent e) {
jButton1_actionPerformed(e);
}
});
this.setSize(new Dimension(664, 300));
this.getContentPane().setLayout(null);
scroll.setBounds(new Rectangle(12, 24, 644, 189));
text1.setBounds(new Rectangle(16, 271, 365, 22));
this.getContentPane().add(scroll, null);
this.getContentPane().add(jButton1, null);
// this.getContentPane().add(text1, null);
scroll.getViewport().add(table1, null);
}
public void userInit()
{
db.connect(); 
vCdata=db.getFieldNames("T_REGISTRATION"); 
dtm=new DefaultTableModel(); 
table1.setModel(dtm); 
for(int i=0;i<vCdata.size();i++)
dtm.addColumn((String)vCdata.elementAt(i));rsRow=db.executeQueryTable("T_REGISTRATION"); 
}/**Start the applet*/
public void start() {
}
/**Stop the applet*/
public void stop() {
}/**Destroy the applet*/
public void destroy() {
}
//static initializer for setting look & feel
static {
try {
//UIManager.setLookAndFeel(UIManager.getSystemLookAndFeelClassName());
//UIManager.setLookAndFeel(UIManager.getCrossPlatformLookAndFeelClassName());
}
catch(Exception e) {
}
}
void jButton1_actionPerformed(ActionEvent e)
{try
{while(rsRow.next())
{
Vector vRdata=new Vector();
for(int i=0;i<vCdata.size();i++)
{
vRdata.addElement(rsRow.getString((String)vCdata.elementAt(i))); 
}
dtm.addRow(vRdata); 
}
db.close();
}catch(Exception ei)
{
System.out.println("error at jButton1_actionPerformed! in TestDatabase" + ei.toString());
}}
}
你可以在TestDatabase 类中增强功能如更新3行4列的数据:dtm.setValueAt("bigCat",3,4),也可以table1.setValueAt("bigCat",3,4).
得出3行4列数据:Object rs=dtm.getValueAt(3,4);
delete第3行数据:dtm.removeRow(3)

解决方案 »

  1.   

    得用
    String query_1="select * from 语文 where 作品类型=? union select * from 数学 where 作品类型=? union select * from 英语 where 作品类型=? union select * from 信息 where 作品类型=?";
    PreparedStatement pstate = con.prepareStatement(query_1);
    pstate.setString(1,jText2);
    pstate.setString(2,jText2);
    pstate.setString(3,jText2);
    pstate.setString(4,jText2);
      

  2.   

    现在什么问题都不讨论,只考虑类与类之间的调用问题,
     void jButton2_actionPerformed(ActionEvent e) {
       main2Frame2 newjTable=new main2Frame2();
       newjTable.queryDataSet1.close();
       database1.setConnection(new com.borland.dx.sql.dataset.ConnectionDescriptor("jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=中小学学生查询工具", "sa", "", false, "com.microsoft.jdbc.sqlserver.SQLServerDriver"));
       queryDataSet1.setQuery(new com.borland.dx.sql.dataset.QueryDescriptor(database1, "select * from 语文", null, true, Load.ALL));
       newjTable.jdbTable1.setDataSet(queryDataSet1);
      }
    我把我的程序改成这样了,在一个FRAME中有这么一个方法,我创建了
        private Database database1 = new Database();
        private QueryDataSet queryDataSet1 = new QueryDataSet();
    然后在main2Frame2 这个FRAME中的jdbTable1中来显示数据库queryDataSet1。
    可还是不行。
            首先你们说说这样能不能显示成,main2Frame2在这个void jButton2_actionPerformed(ActionEvent e) 方法后是不是需要专门的刷新才能显示?来着有分!
      

  3.   

    to  study_body(珍惜每一天) :
      这样不行,我的 main2Frame2本来显示着,我是想再原来的main2Frame2的实例FRAME中刷新为现在的数据库显示。你这样,也就是生成了一个新的FRAME,然后再这个新的FRAME中显示了。