也许有人可以帮助我。我正在使用数据访问对象。我有一个数据库:表 Receiverz
num name
1 Walmart
2 Target
3 McDonalds
我为这个表创建了一个类
public class Receiverz {
private int num;
private String name;
public void setNum(int num) {
this.num = num;
}
public void setName(String name) {
this.name = name;
}
}
然后我创建了 Dao 接口并传递了一个方法给它:
public interface Dao {
Receiverz getReceiverz(int num);}
然后我创建了一个实现 Dao 的类 ExpensesDao 并在其中创建了一个单例(我也设置了与数据库的连接,但我将跳过该部分)并通过使其可以使用数据库来覆盖 getReceivers(int num) 方法:
public class ExpensesDao implements Dao {
private static Dao thisdao;
public static synchronized Dao getDao() {
if (thisdao==null) {
thisdao = new ExpensesDao();
}
return thisdao;
}
@Override
public Receiverz getReceiverz(int num) {
Receiverz receiver = new Receiverz();
try {
Statement stmt = myConnection.createStatement();
ResultSet result = stmt.executeQuery("SELECT * FROM receiverz");
while(result.next()){
receiver.setNum(num);
receiver.setName(result.getString(2));
}
}
catch (SQLException e){
System.out.println(e.getMessage());
}
return receiver;
}
当我尝试在主类中运行它时:
public class TryDatabase {
public static void main(String[] args) {
Dao ex = ExpensesDao.getDao();
System.out.println(ex.getReceiverz(2));
我得到的是:
listexpenses.Receiverz@193499fd
但我必须得到
2 Target
(因为我在参数中传递了 2 并且它引用了我的数据库中的 Target。有谁知道出了什么问题以及我应该在我的代码中更改什么。PS 我希望我说得足够清楚。