我写了一个简单的程序从数据库中提取一些数据,数据库表中的每一行都是在我使用普通构造函数创建的对象中构建的,然后我使用.add()将该对象添加到我的arraylist中方法。 我的问题是,当我打印出我的arraylist包含的内容时,我发现所有的情况只包含数据库中的最后一行!!我试图打印,同时添加到arraylist,我发现每次我添加一个新的对象,它在arraylist的新的和旧的情况下,所以最后一个对象(代表数据库的表的最后一行)得到在所有的arraylist! 所以任何帮助PLZ?
这是我的两个班级: 的 Client.java
public class Client {
public static String nom, prenom, adrs;
private static int id, maxcredit, totalpaye, totalnonpaye;
//i want data to be stored in this arraylist
public static ArrayList<ClientInfo> clients = new ArrayList();
public Client(){
connectDB();//connecting to the database
getClients();//storing the data from the database to arraylist!!
}
private static Connection conn = null;
private static Statement stmt = null;
private static ResultSet rs = null;
private static final String Conn_string = "jdbc:mysql://localhost/carnetcredit";
//Connect to DB:
public static void connectDB(){
try{
conn = DriverManager.getConnection(Conn_string, "root", "");
}catch(SQLException e){
System.err.println(e);
}
}
//Get all clients list:
public static void getClients(){
try{
stmt = conn.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE, ResultSet.CONCUR_READ_ONLY);
rs = stmt.executeQuery("select * from client");
System.out.println("Table Client : ");
while (rs.next()){
//getting data from database to simpte variables
id = rs.getInt("idclient");
nom = rs.getString(2);
prenom = rs.getString(3);
adrs = rs.getString(4);
maxcredit = rs.getInt(5);
totalpaye = rs.getInt(6);
totalnonpaye = rs.getInt(7);
//creating an object using the data extracted from the database
ClientInfo client = new ClientInfo(id,nom,prenom,adrs,maxcredit,totalpaye,totalnonpaye);
//adding the object to the arraylist
clients.add(client);
}
}catch(SQLException e){
System.err.println(e);
}
}
//::::::::::::::::::::::::::::::::::::::::::::::::::: Main Method :::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::
public static void main(String[] args) {
conn = null;
stmt = null;
rs = null;
ClientInfo client = new ClientInfo();
new Client();
int i = 0;
while (i<clients.size()){
client = clients.get(i);
System.out.println("id : "+ client.id +" - nom : "+client.nom+" - prenom : "+client.prenom+" - adresse : "+client.adrs+
" - maxcredit : "+client.maxcredit+" - total payé : "+client.totalpaye+" - total non payé : "+client.totalnonpaye);
i++;
}
}
//:::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::
}
ClientInfo.java
public class ClientInfo {
public String nom, prenom, adrs;
public int id, maxcredit, totalpaye, totalnonpaye;
public ClientInfo(){
id = 0;
nom = prenom = adrs = "";
maxcredit = totalpaye = totalnonpaye = 0;
}
public ClientInfo(int id, String nom, String prenom, String adrs, int maxcredit, int totalpaye,int totalnonpaye){
this.id = id;
this.nom = nom;
this.prenom = prenom;
this.adrs = adrs ;
this.maxcredit = maxcredit ;
this.totalpaye = totalpaye ;
this.totalnonpaye = totalnonpaye;
}
}
谢谢你们!
答案 0 :(得分:5)
每当我看到
仅包含数据库的最后一行
我自动知道这是由静态变量引起的。
更改
public static String nom, prenom, adrs;
private static int id, maxcredit, totalpaye, totalnonpaye;
是非静态的