我有一个抽象类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,但他们也会这样做。有没有干净的方法来做到这一点......
他们可能是一个简单的解决方案,但我只是没有看到它。