列表元素未正确累积
list elements not accumulating properly
学年模型
public class SchoolYear {
int id;
int start;
int end;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public int getStart() {
return start;
}
public void setStart(int start) {
this.start = start;
}
public int getEnd() {
return end;
}
public void setEnd(int end) {
this.end = end;
}
}
SchoolYearDaoImplclass方法
public List<SchoolYear> getAllSchoolYearStart() {
String SQL = "{CALL getAllSchoolYearInfo()}";
SchoolYear schoolyear = new SchoolYear();
List<SchoolYear> list = new ArrayList<>();
try(Connection con = DBUtil.getConnection(DBType.MYSQL);
CallableStatement cs = con.prepareCall(SQL);){
try(ResultSet rs = cs.executeQuery();){
while(rs.next()){
schoolyear.setStart(rs.getInt("yearFrom"));
list.add(schoolyear);
}
JOptionPane.showMessageDialog(null,list.size());
for(int x=0; x<list.size(); x++){
JOptionPane.showMessageDialog(null,((SchoolYear)list.get(x)).getStart());
}
}
}catch(SQLException e){
JOptionPane.showMessageDialog(null,e.getMessage());
}
return list;
}
我通过调用存储过程 getAllSchoolYearInfo()
获得的结果集显示 yearFrom 列的 2 行。
但是,当我 运行 程序查看我的 GUI 上有什么时,我在 JComboBox
中得到 2 个值,这似乎是第 2 行的值 2015
如您所见,我试图获取列表的大小以查看存储了多少对象。所以我猜这可能是对象如何存储和累积到此代码块中的 List<SchoolYear>
的问题。
try(ResultSet rs = cs.executeQuery();){
while(rs.next()){
schoolyear.setStart(rs.getInt("yearFrom"));
list.add(schoolyear);
}
JOptionPane.showMessageDialog(null,list.size());
for(int x=0; x<list.size(); x++){
JOptionPane.showMessageDialog(null,((SchoolYear)list.get(x)).getStart());
}
}
或者问题出在我的 ListCellRenderer
上?我认为不是。
jcmbSchoolYearStart.setRenderer(new DefaultListCellRenderer() {
@Override
public Component getListCellRendererComponent(JList list, Object value, int index, boolean isSelected, boolean cellHasFocus) {
super.getListCellRendererComponent(list, value, index, isSelected, cellHasFocus);
if(value instanceof SchoolYear){
SchoolYear schoolyear = (SchoolYear) value;
setText(""+schoolyear.getStart());
}
return this;
}
} );
有什么想法吗?
谢谢。
您只创建了一个 SchoolYear
实例。因为您这样做了,所以您的 list
中只有一个引用。您可以注释掉当前的 SchoolYear schoolyear
并将其移动到循环中(并修复您正在使用它的任何其他地方),或者只是在循环中声明一个新的局部变量,例如。
while(rs.next()){
SchoolYear sy = new SchoolYear();
sy.setStart(rs.getInt("yearFrom"));
list.add(sy);
}
学年模型
public class SchoolYear {
int id;
int start;
int end;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public int getStart() {
return start;
}
public void setStart(int start) {
this.start = start;
}
public int getEnd() {
return end;
}
public void setEnd(int end) {
this.end = end;
}
}
SchoolYearDaoImplclass方法
public List<SchoolYear> getAllSchoolYearStart() {
String SQL = "{CALL getAllSchoolYearInfo()}";
SchoolYear schoolyear = new SchoolYear();
List<SchoolYear> list = new ArrayList<>();
try(Connection con = DBUtil.getConnection(DBType.MYSQL);
CallableStatement cs = con.prepareCall(SQL);){
try(ResultSet rs = cs.executeQuery();){
while(rs.next()){
schoolyear.setStart(rs.getInt("yearFrom"));
list.add(schoolyear);
}
JOptionPane.showMessageDialog(null,list.size());
for(int x=0; x<list.size(); x++){
JOptionPane.showMessageDialog(null,((SchoolYear)list.get(x)).getStart());
}
}
}catch(SQLException e){
JOptionPane.showMessageDialog(null,e.getMessage());
}
return list;
}
我通过调用存储过程 getAllSchoolYearInfo()
获得的结果集显示 yearFrom 列的 2 行。
但是,当我 运行 程序查看我的 GUI 上有什么时,我在 JComboBox
中得到 2 个值,这似乎是第 2 行的值 2015
如您所见,我试图获取列表的大小以查看存储了多少对象。所以我猜这可能是对象如何存储和累积到此代码块中的 List<SchoolYear>
的问题。
try(ResultSet rs = cs.executeQuery();){
while(rs.next()){
schoolyear.setStart(rs.getInt("yearFrom"));
list.add(schoolyear);
}
JOptionPane.showMessageDialog(null,list.size());
for(int x=0; x<list.size(); x++){
JOptionPane.showMessageDialog(null,((SchoolYear)list.get(x)).getStart());
}
}
或者问题出在我的 ListCellRenderer
上?我认为不是。
jcmbSchoolYearStart.setRenderer(new DefaultListCellRenderer() {
@Override
public Component getListCellRendererComponent(JList list, Object value, int index, boolean isSelected, boolean cellHasFocus) {
super.getListCellRendererComponent(list, value, index, isSelected, cellHasFocus);
if(value instanceof SchoolYear){
SchoolYear schoolyear = (SchoolYear) value;
setText(""+schoolyear.getStart());
}
return this;
}
} );
有什么想法吗?
谢谢。
您只创建了一个 SchoolYear
实例。因为您这样做了,所以您的 list
中只有一个引用。您可以注释掉当前的 SchoolYear schoolyear
并将其移动到循环中(并修复您正在使用它的任何其他地方),或者只是在循环中声明一个新的局部变量,例如。
while(rs.next()){
SchoolYear sy = new SchoolYear();
sy.setStart(rs.getInt("yearFrom"));
list.add(sy);
}