Here are the steps I did for this model project based on the HR demo schema.
The first step is to create the EJB project and generate the entity classes.
data:image/s3,"s3://crabby-images/25550/255500123eaa27810daecaa5d719664e3f22ae15" alt=""
data:image/s3,"s3://crabby-images/48fc6/48fc6da40d22300a95805cb84c1ef05742562d33" alt=""
Add the relations manually between the department and employee entities.
data:image/s3,"s3://crabby-images/a8a2e/a8a2e5ba71a5950265f062e5ddda50727762112d" alt=""
Add the Oracle sequences definitions to the primary keys
data:image/s3,"s3://crabby-images/40e1e/40e1ed61ff2b21d6668f3e0acedce6a0b098379f" alt=""
data:image/s3,"s3://crabby-images/7819d/7819d05cd2ac9bf17fc49cb5882852b6830e08db" alt=""
Create an session bean
data:image/s3,"s3://crabby-images/16a3a/16a3ad773267638cdfb1400b22e1046422bc349c" alt=""
And make an EJB client to test the session.
data:image/s3,"s3://crabby-images/f30b4/f30b46476ca2683d6357105ace7a7bd62b618f21" alt=""
package nl.whitehorses.eclipselink.model.client;
import java.sql.Timestamp;
import java.util.Date;
import java.util.Hashtable;
import java.util.List;
import javax.naming.Context;
import javax.naming.InitialContext;
import javax.naming.NamingException;
import nl.whitehorses.eclipselink.model.entities.Departments;
import nl.whitehorses.eclipselink.model.entities.Employees;
import nl.whitehorses.eclipselink.model.services.HrSession;
public class HrSessionClient {
public static void main(String [] args) {
try {
final Context context = getInitialContext();
HrSession hrSession = (HrSession)context.lookup("Eclipselink-HrSession#nl.whitehorses.eclipselink.model.services.HrSession");
// insert new department
Departments department = new Departments();
department.setDepartmentName("Sales");
department.setLocationId(1700L);
department.setManagerId(200L);
department = (Departments)hrSession.mergeEntity(department);
System.out.println("new department id: "+department.getDepartmentId());
// add a new employee
Employees employee1 = new Employees();
employee1.setEmail("Test1@test.nl");
employee1.setLastName("Test1");
employee1.setJobId("ST_MAN");
employee1.setHireDate(new Timestamp(new Date().getTime()));
department.addEmployees(employee1);
department = (Departments)hrSession.mergeEntity(department);
// add a other new employee
Employees employee2 = new Employees();
employee2.setEmail("Test2@test.nl");
employee2.setLastName("Test2");
employee2.setJobId("ST_MAN");
employee2.setHireDate(new Timestamp(new Date().getTime()));
employee2.setDepartment(department);
department.getEmployees().add(employee2);
department = (Departments)hrSession.mergeEntity(department);
// retrieving the new department with its employees
for (Departments departments : (List<Departments>)hrSession.queryDepartmentsFindOne( department.getDepartmentId())) {
System.out.println( "departmentId = " + departments.getDepartmentId() );
System.out.println( "departmentName = " + departments.getDepartmentName() );
System.out.println( "locationId = " + departments.getLocationId() );
System.out.println( "managerId = " + departments.getManagerId() );
for (Employees employees : departments.getEmployees()) {
System.out.println( "employeeId = " + employees.getEmployeeId() );
System.out.println( "commissionPct = " + employees.getCommissionPct() );
System.out.println( "email = " + employees.getEmail() );
System.out.println( "firstName = " + employees.getFirstName() );
System.out.println( "hireDate = " + employees.getHireDate() );
}
}
} catch (Exception ex) {
ex.printStackTrace();
}
}
private static Context getInitialContext() throws NamingException {
Hashtable env = new Hashtable();
// WebLogic Server 10.x connection details
env.put( Context.INITIAL_CONTEXT_FACTORY, "weblogic.jndi.WLInitialContextFactory" );
env.put(Context.PROVIDER_URL, "t3://127.0.0.1:7101");
return new InitialContext( env );
}
}
No comments:
Post a Comment