0

也许有人可以帮助我。我正在使用数据访问对象。我有一个数据库:表 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 我希望我说得足够清楚。

4

3 回答 3

2

ex.getReceiverz(2)正在返回一个Receiverz对象。因此,System.out.println(ex.getReceiverz(2));使用toString()继承自 的方法java.lang.Object。在类中创建一个toString()方法,Receiverz以您想要的方式输出它。

于 2012-04-19T20:55:21.943 回答
0

将 getName 添加到您的接收者并更改为此 ex.getReceiverz(2).getName()

于 2012-04-19T20:52:23.553 回答
0

有点离题,但我建议使用双重检查锁定单例代码来避免初始化中的所有并发问题。

Ps.: ex.getReceiverz(2).getName() 违反了 Demeter 法则,最好避免它。

于 2012-04-19T21:16:26.720 回答