??为什么不能实现??

hooligan31000 2004-04-18 10:47:33
有JcomboBox(学号)控件连接数据库,单击它,显示相应的记录,“姓名”“年龄”,为什么不能实现??谢谢!!!

import java.sql.*;
import java.awt.*;
import javax.swing.*;
import java.awt.event.*;

public class choice extends JFrame implements ActionListener,ItemListener
{
private Connection conn;
private Statement stmt;
private ResultSet rs;
private String url="jdbc:odbc:star";
JComboBox j;
JTextField t1,t2;
Container content;
public choice()
{
content=getContentPane();
content.setLayout(new FlowLayout());
j=new JComboBox();
t1=new JTextField(10);
t2=new JTextField(10);
content.add(j);
content.add(t1);
content.add(t2);
try
{
Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
conn=DriverManager.getConnection(url);
stmt=conn.createStatementResultSet.TYPE_SCROLL_SENSITIVE,ResultSet.CONCUR_UPDATABLE);
String query;
query="select * from card";
rs=stmt.executeQuery(query);
rs.beforeFirst();
while(rs.next()) //显示JComboBox的内容(卡号)
{
String CardId=rs.getString(1);
j.addItem(CardId);


}
rs.close(); //关闭
stmt.close();

}catch(Exception ex)
{
System.out.println(ex.getMessage());
}


}

public static void main(String args[])
{
JFrame.setDefaultLookAndFeelDecorated(true);
choice cc=new choice();
cc.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
cc.setTitle("choice");
cc.setSize(500,500);
cc.show();

}

public void actionPerformed(ActionEvent ae)
{
}

public void itemStateChanged(ItemEvent ie)
{
try{
conn=DriverManager.getConnection(url);
stmt=conn.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,ResultSet.CONCUR_UPDATABLE);

String query1,strstr;
strstr=(String)(j.getSelectedItem());
query1="select * from card where 卡号='"+strstr+"'";


rs=stmt.executeQuery(query1);

t1.setText(rs.getString(2));
t2.setText(rs.getString(8));

rs.close(); //关闭
stmt.close();

}catch(Exception ex)
{
System.out.println(ex.getMessage());
}

}

}
...全文
96 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
hooligan31000 2004-04-19
  • 打赏
  • 举报
回复
我加了个BUTTON,还是不行??
public void actionPerformed(ActionEvent ae)
{
String str,query1;
str=(String)j.getSelectedItem();
System.out.println(str);
try{
conn=DriverManager.getConnection(url);
stmt=conn.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,ResultSet.CONCUR_READ_ONLY);


query1="select 姓名,现有金额 from card where 卡号="+str;

rs=stmt.executeQuery(query1);

System.out.println("name"+rs.getString("姓名"));

String str1,str2;

str1=rs.getString("姓名");
str2=rs.getString("现有金额");
t1.setText(str1);
t2.setText(str2);
//t1.setText(rs.getString("姓名"));
//t2.setText(rs.getString("现有金额"));

System.out.println(rs.getString(2));
System.out.println(rs.getString(8));


rs.close(); //关闭
stmt.close();
}catch(Exception eee)
{}
}
hooligan31000 2004-04-19
  • 打赏
  • 举报
回复
怎么测试?JComboBox的事件不是itemStateChanged(ItemEvent ie),与actionPerformed有关系吗?
yongfans 2004-04-19
  • 打赏
  • 举报
回复
那你在actionPerformed中测试一下看它是否执行到那里,在有你和数据库连接,有没有用户名,密码。
hooligan31000 2004-04-19
  • 打赏
  • 举报
回复
我加上了,还是没反应?
yongfans 2004-04-19
  • 打赏
  • 举报
回复
你没有在Jcombox中加入事件啊
你加入 j.addItemListener(this);
hooligan31000 2004-04-19
  • 打赏
  • 举报
回复
up
内容概要:本文系统阐述了嵌入式功能安全领域的两大核心标准——IEC 61508与ISO 26262的完整体系,涵盖其定位、关系、技术要求及认证流程。IEC 61508作为通用工业功能安全基础标准,适用于PLC、机器人、轨道交通等系统,采用SIL等级划分;ISO 26262则是其在汽车行业的衍生标准,专用于车载电控单元(如BMS、ESP、自动驾驶控制器),采用ASIL等级评估。文章详细解析了两个标准在风险评估方法(如HARA与风险图法)、软硬件设计规范、失效分析、安全机制实现(如看门狗、CRC校验、冗余设计)等方面的异同,并提供了从需求分析到认证落地的全流程实施路径,包括安全生命周期管理、文档证据链构建及第三方认证机构介绍。; 适合人群:从事工业自动化或汽车电子领域嵌入式系统设计、功能安全开发与认证工作的工程师、项目经理及安全分析师,具备一定电子电气或软件开发背景的专业人员; 使用场景及目标:①指导企业开展符合IEC 61508或ISO 26262的功能安全产品设计与认证;②帮助研发团队理解SIL/ASIL等级判定逻辑与软硬件安全机制实现方式;③支持撰写安全需求文档、FMEDA报告及准备第三方审核材料; 阅读建议:此资源兼具理论体系与工程实践,建议结合具体项目场景对照标准条款进行研读,并重点关注安全生命周期各阶段的交付物要求与典型安全防护设计示例,以提升实际应用能力。

62,621

社区成员

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

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