- Jakarta EE Cookbook
- Elder Moraes
- 239字
- 2021-06-24 16:12:46
How to do it...
You need to perform the following steps to complete this recipe:
- First, we need to create our persistence unit (at persistence.xml):
<persistence-unit name="ch02-jta-pu" transaction-type="JTA">
<provider>org.hibernate.ejb.HibernatePersistence</provider>
<jta-data-source>userDb</jta-data-source>
<non-jta-data-source>userDbNonJta</non-jta-data-source>
<exclude-unlisted-classes>false</exclude-unlisted-classes>
<properties>
<property name="javax.persistence.schema-
generation.database.action"
value="create"/>
</properties>
</persistence-unit>
- Then, we need to create a User class as an entity (@Entity):
@Entity
public class User implements Serializable {
private static final long serialVersionUID = 1L;
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
private Long id;
private String name;
private String email;
protected User() {
}
public User(Long id, String name, String email) {
this.id = id;
this.name = name;
this.email = email;
}
//DO NOT FORGET TO IMPLEMENT THE GETTERS AND SETTERS
}
- We also need a Jakarta Enterprise Bean (formerly EJB) to perform the operations over the User entity:
@Stateful
public class UserBean {
@PersistenceContext(unitName = "ch02-jta-pu",
type = PersistenceContextType.EXTENDED)
private EntityManager em;
public void add(User user){
em.persist(user);
}
public void update(User user){
em.merge(user);
}
public void remove(User user){
em.remove(user);
}
public User findById(Long id){
return em.find(User.class, id);
}
}
- Then, we need to create our unit test:
public class Ch02JtaTest {
private EJBContainer ejbContainer;
@EJB
private UserBean userBean;
public Ch02JtaTest() {
}
@Before
public void setUp() throws NamingException {
Properties p = new Properties();
p.put("userDb", "new://Resource?type=DataSource");
p.put("userDb.JdbcDriver", "org.hsqldb.jdbcDriver");
p.put("userDb.JdbcUrl", "jdbc:hsqldb:mem:userdatabase");
ejbContainer = EJBContainer.createEJBContainer(p);
ejbContainer.getContext().bind("inject", this);
}
@After
public void tearDown() {
ejbContainer.close();
}
@Test
public void validTransaction() throws Exception{
User user = new User(null, "Elder Moraes",
"elder@eldermoraes.com");
userBean.add(user);
user.setName("John Doe");
userBean.update(user);
User userDb = userBean.findById(1L);
assertEquals(userDb.getName(), "John Doe");
}
}
推薦閱讀
- DB2 V9權威指南
- ClickHouse性能之巔:從架構設計解讀性能之謎
- 自制編譯器
- 機械工程師Python編程:入門、實戰與進階
- Getting Started with Greenplum for Big Data Analytics
- Mastering ROS for Robotics Programming
- Rust游戲開發實戰
- 區塊鏈項目開發指南
- Web程序設計:ASP.NET(第2版)
- Sails.js Essentials
- Building Business Websites with Squarespace 7(Second Edition)
- 高質量程序設計指南:C++/C語言
- C#程序開發參考手冊
- Python人工智能項目實戰
- Java EE框架開發技術與案例教程