这里,
ViewAlbum album = new ViewAlbum();// ...while (resultSet.next()) { album.setAlbumid(resultSet.getInt("albumid")); // ... allAlbums.add(album);}您将
album所有记录重复使用相同的实例。实例的数据在循环中每次都被覆盖。该列表不包含实例的副本,但包含单个实例的 引用
的副本。您知道,Java是面向对象的。
您应该为
album每个记录创建一个新实例。将实例移到循环内部。
// ...while (resultSet.next()) { ViewAlbum album = new ViewAlbum(); album.setAlbumid(resultSet.getInt("albumid")); // ... allAlbums.add(album);}与 具体问题 无关 ,您应该在
finally块中关闭JDBC资源,或者在
try()try-with-
resources语句中打开它们,否则在执行查询或处理结果集期间发生异常时,它们仍会泄漏出去。您还应该将JDBC资源的声明移到方法块内部,否则也会遇到线程安全性问题。最后但并非最不重要的一点是,您应该使用setter方法
PreparedStatement在SQL字符串中设置用户控制的变量。如果它们是字符串,那么您将有一个SQL注入攻击孔。



