我的項目中有一個DAO層。這裏是我的UsersDao接口和它的實現UsersDaoImpl如何在服務層進行交易
public interface UsersDao {
public Users insert(Users object);
}
public class UsersDaoImpl implements UsersDao {
@Override
public Users insert(Users object) {
String sqlQuery = null;
PreparedStatement stmt = null;
try (Connection connection = DbConnector.getConnection()) {
sqlQuery = "INSERT INTO `users`(login, password,passwordSalt, name, surname)" + " values (?, ?,?,?,?);";
stmt = connection.prepareStatement(sqlQuery);
stmt.setString(1, "fsf");
stmt.setString(2, "f");
stmt.setString(3, "af");
stmt.setString(4, "fddsg");
stmt.setString(5, "sdgsgd");
stmt.executeUpdate();
stmt.close();
return object;
} catch (SQLException e) {
System.err.println(e.getMessage());
return null;
}
}
這裏是我的服務層的類和接口。
public interface UsersService{
public Users insert(Users object);
}
public class UsersServiceImpl implements UsersService{
UsersDaoImpl users = new UsersDaoImpl();
public Users insert(Users object){
return users.insert(object);
}
什麼我需要寫入我的服務方法,我可以使異常捕獲時回滾?如何在我的服務方法中寫入交易?你能告訴我一些例子嗎?感謝名單!
在Java EE一下,您通常使用EJB了點。這是否適用於您的環境?因爲您使用JDBC樣板代替JPA oneliner,這一事實強烈建議您使用像Tomcat這樣的準系統servlet容器,而不是普通的Java EE服務器。 – BalusC