jdbc连接数据库得到列名和值,显示在JTable中出错,已经郁闷到内伤!

hawaii_wx 2005-08-03 03:44:05
小弟近来学习jdbc,想把表的内容显示到JTable中,但是老是出问题,请大家帮帮我,看看我的代码哪里错了?谢谢!
下面是我写的代码:

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.ResultSetMetaData;
import java.sql.SQLException;
import java.sql.Statement;

import javax.swing.JFrame;

import javax.swing.JTable;
/**
* @author Administrator
*
* TODO 要更改此生成的类型注释的模板,请转至
* 窗口 - 首选项 - Java - 代码样式 - 代码模板
*/
public class JTableTest extends JFrame {

private javax.swing.JPanel jContentPane = null;
private JTable jTable = null;
String[] columnNames=null;

Object[][] data=null;

/**
* This method initializes jTable
*
* @return javax.swing.JTable
*/
// private JTable getJTable() {
// if (jTable == null) {
// jTable = new JTable(data,columnNames);
// }
// return jTable;
// }
public static void main(String[] args) throws Exception {
JTableTest t=new JTableTest();
t.show();
System.out.println("ooookkkkkkk");
}
/**
* This is the default constructor
* @throws Exception
*/
public JTableTest() throws Exception {

initialize();
}
/**
* This method initializes this
*
* @return void
* @throws Exception
*/
private void initialize() throws Exception {

Class.forName("com.microsoft.jdbc.sqlserver.SQLServerDriver");
String url="jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=pubs";
Connection con=DriverManager.getConnection(url,"sa","sa");
Statement stmt=con.createStatement();
ResultSet rs=stmt.executeQuery("select * from authors");
ResultSetMetaData rsm=rs.getMetaData();
for(int i=1;i<rsm.getColumnCount();i++)
{
columnNames[i-1]=rsm.getColumnName(i);
}
//while(rs.next())
for(int j=1;j<rs.getRow();j++)
{
for(int i=1;i<rsm.getColumnCount();i++)
{
data[j-1][i-1]=rs.getObject(i);
}
}
rs.close();
stmt.close();
con.close();

jTable = new JTable(data,columnNames);
this.setContentPane(jTable);
this.setSize(676, 383);
this.setTitle("JFrame");
}
/**
* This method initializes jContentPane
*
* @return javax.swing.JPanel
*/
private javax.swing.JPanel getJContentPane() {
if(jContentPane == null) {
jContentPane = new javax.swing.JPanel();
jContentPane.setLayout(new java.awt.BorderLayout());
}
return jContentPane;
}
} // @jve:decl-index=0:visual-constraint="92,25"

我感觉我自己的写的代码没错了,但是运行的时候就是报错,以下是报错的内容:

java.lang.NullPointerException
at j2ee_bean.JTableTest.initialize(JTableTest.java:73)
at j2ee_bean.JTableTest.<init>(JTableTest.java:55)
at j2ee_bean.JTableTest.main(JTableTest.java:45)
Exception in thread "main"

唉,郁闷呀!
...全文
317 10 打赏 收藏 转发到动态 举报
写回复
用AI写文章
10 条回复
切换为时间正序
请发表友善的回复…
发表回复
luwenshuo 2005-08-04
  • 打赏
  • 举报
回复
这个你自己去找吧,.主要看DefaultTableModel的使用 这是我很久以前做的了,应该没问题我这里没装工具也不好测试,你先看看吧

import java.awt.*;
import java.awt.event.*;
import java.util.*;
import javax.swing.table.*;
import javax.swing.*;
import javax.swing.event.*;

public class classMain extends JInternalFrame {


public classMain() {
frm = this;
initComponents();
setVisible(true);
}

private void initComponents() {
font = new Font("新宋体",Font.PLAIN,12);
jTitle = new JLabel();
classTable = new JTable();
btOK = new JButton();

getContentPane().setLayout(null);

setDefaultCloseOperation(WindowConstants.EXIT_ON_CLOSE);
jTitle.setFont(new java.awt.Font("新宋体", 0, 14));
jTitle.setText("班级一览表");
getContentPane().add(jTitle);
jTitle.setBounds(250, 10, 120, 20);

classTable.setFont(font);

JScrollPane sl = new JScrollPane(classTable);

getContentPane().add(sl);
sl.setBounds(0, 60, 590, 360);
initclassTable();

getContentPane().add(btOK);
btOK.setBounds(420, 440, 70, 25);

btOK.setFont(new java.awt.Font("新宋体", 0, 12));
btOK.setText("确定");
getContentPane().add(btOK);
btOK.setBounds(510, 440, 70, 25);
btOK.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent e) {
frm.setVisible(false);
}
});

Dimension screenSize = Toolkit.getDefaultToolkit().getScreenSize();
setBounds((screenSize.width-600)/2, (screenSize.height-515)/2, 600, 515); //设置窗口大小
}

private void initclassTable() {
String title[] = new String[]{"班级名称","开班日期","学期","班主任姓名","上课时间"};
dtm = new DefaultTableModel(null,title);
classTable.setModel(dtm);
DBclass.query("select * from class");
try{
Vector v;
while(DBclass.rs.next()) { //rs为数据库模块的记录集
v = new Vector();
v.addElement(DBclass.rs.getString("className"));
v.addElement(DBclass.rs.getString("classDate"));
v.addElement(DBclass.rs.getString("classTerm"));
v.addElement(DBclass.rs.getString("classTeacherName"));
v.addElement(DBclass.rs.getString("classTime"));

dtm.addRow(v);
}

}catch(Exception e) {
System.out.println("classMain(initclassTable): " + e.getMessage());
}
}



public static void main(String args[]) {
DBclass.joinDB(); //连接数据库类
new classMain().setVisible(true);

}
private classMain frm;
private DefaultTableModel dtm;
private Font font;
private JButton btOK;
private JTable classTable;
private JLabel jTitle;

}
hawaii_wx 2005-08-03
  • 打赏
  • 举报
回复
楼上的哥们,能给我个例子看看吗?

我可以肯定的说绝对不是jdbc的问题,我后来发现rs.getRow();这个方法没起到作用,后来我换了一个方法,就是把行数取出来,但是就上面的方法还是不行
我自己写把上面的代码修改了下,勉强可以在JTable里面显示出来,但是方法是属于很龌龊的那种!
luwenshuo 2005-08-03
  • 打赏
  • 举报
回复
你是说jdbc部分没问题是吧.你为什么不把数据库中的一行记录读出来放在Vector变量里面,然后读一行就把Vector变量插到JTable里面呢?(用DefaultTableModel实例的addRow方法)
那样很方便阿.应该也不会出现空指针的异常
luwenshuo 2005-08-03
  • 打赏
  • 举报
回复
你用djbc桥连一下看看.,

Connection con=DriverManager.getConnection(url,"sa","sa");
应该就这一句报异常.,
hawaii_wx 2005-08-03
  • 打赏
  • 举报
回复
操作系统是xp的,用的eclipse编辑器在ve的插件下写的代码,sqlserver2000的数据库打了sp3的补丁
luwenshuo 2005-08-03
  • 打赏
  • 举报
回复
你用的操作系统是什麼?
hawaii_wx 2005-08-03
  • 打赏
  • 举报
回复
to: gongyifeng_cs(coffeecat) ( ) 信誉:100
jdbc部分没有问题,3个jar文件导入了,用测试代码在控制台输出表的内容,没有问题!
gongyifeng_cs 2005-08-03
  • 打赏
  • 举报
回复
楼主用的是eclipse的Ve开发的吧?
代码是没错,你sqlserver的jdbc驱动下载了吗,一共好像3个jar文件,你把它们添加到工程的lib目录下在试一试
hawaii_wx 2005-08-03
  • 打赏
  • 举报
回复
这个帖子已经加分到50了,请大家帮帮忙呀,分不是问题呀
hawaii_wx 2005-08-03
  • 打赏
  • 举报
回复
来人呀,
高手,救救我吧!

62,614

社区成员

发帖
与我相关
我的任务
社区描述
Java 2 Standard Edition
社区管理员
  • Java SE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧