也许有人可以帮助我。我正在使用数据访问对象。
我有一个数据库:
表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。
有谁知道出了什么问题以及我应该在代码中进行哪些更改。附言我希望我说得足够清楚。
最佳答案
ex.getReceiverz(2)
返回一个Receiverz
对象。因此,System.out.println(ex.getReceiverz(2));
使用的是从toString()
继承的java.lang.Object
方法。在toString()
类中创建一个Receiverz
方法,该方法将以所需的方式输出。