http://www.javaworld.com/javaworld/javatips/jw-javatip77.html

解决方案 »

  1.   

    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.*;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;  //定义表的列名(以vector存储)
        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);
      }  /*userInit() 数据表格的初始化*/
      public void userInit()
      {
      db.connect();   //数据库连接
      vCdata=db.getFieldNames("T_REGISTRATION");  //得出列名(vector存储)
      dtm=new DefaultTableModel(); //定义模式
      table1.setModel(dtm);  //设定表模式/**for 列出标题烂**/
          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))); //列举列数据(vector存储)
                    }
                 dtm.addRow(vRdata);   //向表中添家数据
                }
              db.close();
          }catch(Exception ei)
          {
          System.out.println("error at jButton1_actionPerformed! in TestDatabase" + ei.toString());
          }  }
    }这个程序简单的实现了数据表格功能,初始化状态是数据表格只有标题,当click 按扭显示数据。1。在userInit()方法中做了数据表格的初始化,关键的方法:
    建立表格模型: DefaultTableModel dtm=new DefaultTableModel(),
    设定表模型:table1.setModel(dtm)
    设定表格标题:(一切操作可以在模型上做) dtm.addColumn(Vector arg),arg是表的标题,也就是field名字数组
    得出数据的结果集合:rsRow=db.executeQueryTable("T_REGISTRATION"),这就是一般的数据查询结果哦2。在 void jButton1_actionPerformed(ActionEvent e)中显示数据,关键方法:
    以行的方式加入数据:dtm.addRow(Vector arg)。3。Jtable有很多的实例化方式,这里采用的是DefaultTableModel模型,对表的操作都可以建立在模型上。4。以后如果更改表中的数据的话可以在模型上修改如:
    更新3行4列的数据:dtm.setValueAt("bigCat",3,4),也可以table1.setValueAt("bigCat",3,4).
    得出3行4列数据:Object rs=dtm.getValueAt(3,4);
    删除第3行数据:dtm.removeRow(3)
    具体数据表格的展现方式大家可以自己修改设定。别人写的 呵呵~~
      

  2.   

    可是我要写入excel文件啊。不是写入jtable
      

  3.   

    把数据以","分隔开保存。保存的文件后缀是excel文件后缀即可。
    不过缺点是没有格式信息。