我有一个抽象类 User 和 3 个从这个类扩展的类(Admin、Modurator、Lector)。
在我的数据库中,我有一个表用户,其中包含所需的数据(用户名/密码/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,但它们会做同样的事情。有没有一种干净的方法可以做到这一点......
他们也许是一个简单的解决方案,但我只是没有看到它。