抽象类 - 扩展类和DAO

时间:2012-04-18 21:50:21

标签: java mysql dao

我有一个抽象类User和3个从这个类扩展的类(Admin,Modurator,Lector)。

在我的数据库中,我有一个用户表,其中包含所需的数据(UserName / Password / Security_lvl)。

用户的数据库连接我使用DAO。

public class MysqlUserDao implements UserDao {
    //
    private static MysqlUserDao instance;

    //
    public static MysqlUserDao getInstance() {
        if (instance == null)
            instance = new MysqlUserDao();
        return instance;
    }
public void create(User user) {
        try {
            c = MySqlDAOFactory.getInstance().getConnection();
            //
            String sql = "insert into user values (?,?,?)";
            //
            prest = c.prepareStatement(sql);
            //
            prest.setString(1, user.getUserName());
            prest.setString(2, user.getPassword());
            prest.setInt(3, user.getRole().returnSecurityLevel());
            //
            prest.executeUpdate();
            //
        } catch (SQLException e) {
            JdbcLogging.info("error item" + " :"
                    + e);
        } finally {
            MySqlConnectionFactory.getInstance().closeResultSet(rs);
            MySqlConnectionFactory.getInstance().closeStatement(prest);
            MySqlConnectionFactory.getInstance().closeConnection(c);
        }
    }

}

在java中,根据用户类型我制作特定的Admin,Modurator或Lector对象,以便我可以使用他们的特定方法。

现在我遇到的问题是,我需要这个DAO的用户。但是User是抽象的,我不做任何User对象。我可以为其他每个类制作三个不同的DAO,但他们也会这样做。有没有干净的方法来做到这一点......

他们可能是一个简单的解决方案,但我只是没有看到它。

1 个答案:

答案 0 :(得分:3)

您可以将Admin,Moderator或Lector实例作为参数传递给create方法。 Java中的Polymorphism允许这种行为。