Prepare database
EMPLOYEE
Column
|
Datatype
|
Nullable
|
EMP_ID
|
NUMBER(22)
|
False
|
EMP_FIRSTNAME
|
VARCHAR2(50)
|
False
|
EMP_SURNAME
|
VARCHAR2(50)
|
True
|
OU_ID
|
NUMBER(22)
|
False
|
BIRTH_DATE
|
DATE
|
True
|
NATIONAL_ID
|
CHAR(13)
|
False
|
EMPLOYEE_BAK
Column
|
Datatype
|
Nullable
|
ID
|
NUMBER(22)
|
True
|
FIRSTNAME
|
VARCHAR2(50)
|
True
|
SURNAME
|
VARCHAR2(50)
|
True
|
OU_ID
|
NUMBER(22)
|
True
|
BIRTH_DATE
|
DATE
|
True
|
NATIONAL_ID
|
CHAR(13)
|
True
|
insertEmployee
CREATE OR REPLACE PROCEDURE OSBDEMO.insertEmployee(
p_emp_firstname IN EMPLOYEE.EMP_FIRSTNAME%TYPE,
p_emp_surname IN EMPLOYEE.EMP_SURNAME%TYPE,
p_ou_id IN EMPLOYEE.OU_ID%TYPE,
p_birth_date IN EMPLOYEE.BIRTH_DATE%TYPE,
p_national_id IN EMPLOYEE.NATIONAL_ID%TYPE)
IS
BEGIN
INSERT INTO OSBDEMO.EMPLOYEE ("EMP_ID", "EMP_FIRSTNAME", "EMP_SURNAME", "OU_ID", "BIRTH_DATE", "NATIONAL_ID")
VALUES (EMP_SEQ.NEXTVAL, p_emp_firstname,p_emp_surname, p_ou_id, p_birth_date, p_national_id);
END;
ทดสอบเรียกใช้งาน
CALL OSBDEMO.insertEmployee('Johny','English',11,SYSDATE,'1234567890123')
ดูผลลัพธ์
SELECT * FROM OSBDEMO.EMPLOYEE ORDER BY EMP_ID DESC
|
Artifact files
Inbound
|
Files
|
Schema
|
xsd/CopyEmployeeService.xsd
|
WSDL
|
CopyEmployeeService.wsdl
|
Proxy Service
|
CopyEmployeeProxyService.proxy
|
Outbound (AddNewEmployee)
|
Files
|
WSDL
|
NewEmployeeService.wsdl
|
JCA config files
|
NewEmployeeService_db.jca
|
Schema
|
xsd/NewEmployeeService_sp.xsd
|
Business Service
|
NewEmployeeService_db.biz
NewEmployeeService_db.wsdl
|
Outbound (QueryAllEmployee)
|
Files
|
WSDL
|
QueryEmployeeService1.wsdl
|
JCA config files
|
QueryEmployeeService1_db.jca
|
Schema
|
xsd/QueryEmployeeService1.xsd
|
Business Service
|
QueryEmployeeService1_db.biz
QueryEmployeeService1_db.wsdl
|
Outbound (ReplicaAllEmployee)
|
Files
|
WSDL
|
MergeEmployeeService1.wsdl
|
JCA config files
|
MergeEmployeeService1_db.jca
MergeEmployeeService1-or-mappings.xml
MergeEmployeeService1-properties.xml
|
Schema
|
MergeEmployeeService1_table.xsd
|
Business Service
|
MergeEmployeeService1_db.biz
MergeEmployeeService1_db.wsdl
|
From
|
To
|
Files
|
Inbound
|
AddNewEmployee
|
CopyEmployeeService_To_NewEmployeeService.xsl
|
Inbound
|
QueryAllEmployee
|
CopyEmployeeService_To_QueryEmployeeService1.xsl
|
Inbound
|
ReplicaAllEmployee
|
CopyEmployeeService_To_MergeEmployeeService1.xsl
|
JDeveloper:
Inbound
xsd =>data:image/s3,"s3://crabby-images/64b5d/64b5decef4de56150ff13858e0bfa2e4f29a8fba" alt=""
wsdl =>data:image/s3,"s3://crabby-images/08ada/08ada58aef5930ff1ab2fab4b60dded5784d35d1" alt=""
Outbound (AddNewEmployee)
สร้าง Database Adapterdata:image/s3,"s3://crabby-images/7e593/7e593959295f9c4bccef1b2eaa8c61ca532bae14" alt=""
data:image/s3,"s3://crabby-images/c79a0/c79a065af9bc35d70027559f65f6711d35bfb6fc" alt=""
data:image/s3,"s3://crabby-images/1bca7/1bca7c00e2b97b388cd9f07047a12c19be4ba774" alt=""
Outbound (QueryAllEmployee)
Outbound (ReplicaAllEmployee)data:image/s3,"s3://crabby-images/6fef4/6fef4c9bc62076da7ac6365747c256ec9e075317" alt=""
data:image/s3,"s3://crabby-images/ff360/ff360c22764d68f04d0aa4056450bfd3a3472c0f" alt=""
data:image/s3,"s3://crabby-images/50c74/50c74e5bf4b90a8131868cbe786a2042c3a170d5" alt=""
Transformation =>
CopyEmployeeService_To_NewEmployeeService.xsldata:image/s3,"s3://crabby-images/b6ac7/b6ac732791ceed4416ab68d880edd0c7bccbffe7" alt=""
CopyEmployeeService_To_QueryEmployeeService1.xsldata:image/s3,"s3://crabby-images/433ad/433adb0479ab7bee0552f6365fb8e9fda3652218" alt=""
CopyEmployeeService_To_MergeEmployeeService1.xsldata:image/s3,"s3://crabby-images/196ec/196ec353ec8eaad9bff902785aa9ae622b8afa7a" alt=""
OEPE:
เปิด Eclipse สร้าง Business Service ทั้ง 3 ตัว ด้วยการ Right-click ที่ jca file และ Generate Servicedata:image/s3,"s3://crabby-images/febdb/febdbf834ce81a1353f519bc1695c094a9f87759" alt=""
สร้างเสร็จสามารถทดสอบ Business Service ด้วย Service Bus Consoledata:image/s3,"s3://crabby-images/0dfd5/0dfd5c66c8afa4ea997d1f2713e94f1ad5e55526" alt=""
สร้าง Proxy Service
- ให้ browse ไปหา WSDL file ที่กำหนด จากนั้นเลือก Bindingdata:image/s3,"s3://crabby-images/3cbe1/3cbe11525ef01e659458618b0c17d93d7629f581" alt=""
OEPE จะ check WSDL file และกำหนด Protocol ให้เรา Confirmdata:image/s3,"s3://crabby-images/180fb/180fb32a092137421bd992b6eb25c0cd22805735" alt=""
กำหนดให้เป็น Transactional Proxy ด้วยการเลือก Transaction Required=Enabled (จะใช้ได้ต้องทำการ configure JDBC driver class เป็น XA ก่อน)data:image/s3,"s3://crabby-images/0f5ac/0f5ac45c4fd196392112ef68026d2e00083eb1a6" alt=""
เริ่มวาด Message Flow ด้วยการ Drag and drop PipelinePairNode1 จาก Design Palettedata:image/s3,"s3://crabby-images/4b730/4b7302b704c69aaa8fad1a6e1739e1d66532c98b" alt=""
สร้าง Stage แรกในขา Request Pipeline ด้วยการ Drag and drop Stage จาก Design Palette
NewEmployee Stagedata:image/s3,"s3://crabby-images/4cda8/4cda80e40ef217bc962d013bd53b9856c6f341ff" alt=""
ภายใน stage นี้ประกอบด้วย Publish action เพื่อเรียก NewExployeeServicedata:image/s3,"s3://crabby-images/5aac7/5aac769b9b6238cfff6a3afc98f4ea3f20b1630e" alt=""
Replace ด้วย XSLdata:image/s3,"s3://crabby-images/538cb/538cbf2c7d8de89ea167eb281b55878e52fcdf07" alt=""
ระบุให้เป็น Synchronous calldata:image/s3,"s3://crabby-images/90e61/90e61f53e5ba7b952f580f1e843a7c61763e3eca" alt=""
Query Stagedata:image/s3,"s3://crabby-images/17366/173667a2f26dffa56da1524fe9bf310d5ace31a6" alt=""
Add Namespaces ใน stage นี้data:image/s3,"s3://crabby-images/1007e/1007ea928fa640f640e0e3ee2e836f3df989cf61" alt=""
ภายใน stage ที่ 2 นี้ประกอบด้วยdata:image/s3,"s3://crabby-images/1f40f/1f40fb8b1a240fdb1924dae544b6b6af1d6c1480" alt=""
Assign ค่าให้ Variabledata:image/s3,"s3://crabby-images/938d5/938d5454162fd3c0a64ccd23cb4558295fcac555" alt=""
ระบุเป็น Synchronous calldata:image/s3,"s3://crabby-images/65700/6570066576afc653b74ce32856924add002fbe37" alt=""
Replace action ให้ใส่ Code ใน Expression
let $in_xml := $QueryResponseVariable
for $i in $in_xml/quer:QueryEmployeeService1Output
let $r :=
<quer:EmployeeBak>
<quer:id>
{ data($i/quer:EMP_ID) }
</quer:id>
<quer:firstname>
{ data($i/quer:EMP_FIRSTNAME) }
</quer:firstname>
<quer:surname>
{ data($i/quer:EMP_SURNAME) }
</quer:surname>
<quer:ouId>
{ data($i/quer:OU_ID) }
</quer:ouId>
<quer:birthDate>
{ data($i/quer:BIRTH_DATE) }
</quer:birthDate>
<quer:nationalId>
{ data($i/quer:NATIONAL_ID) }
</quer:nationalId>
</quer:EmployeeBak>
return $r
|
Replicate Stagedata:image/s3,"s3://crabby-images/46aa6/46aa665be5083786601a15f701041b553c2b81a4" alt=""
Add Namespaces ใน stage นี้data:image/s3,"s3://crabby-images/5c071/5c071dbb10cd5f51224c8577a03248f663b8f47b" alt=""
data:image/s3,"s3://crabby-images/1826e/1826e5dd0a0414456942d6b2ce03fc8fa2d60bc0" alt=""
data:image/s3,"s3://crabby-images/954b5/954b5b8e157f8ca967882087ca6b94f0a5cdcba8" alt=""
data:image/s3,"s3://crabby-images/1cff5/1cff574e24af57c296fe4b261471580ba3a7b839" alt=""
data:image/s3,"s3://crabby-images/2d5b8/2d5b872a82cb7db0f77357f048d2e4b4abfe627d" alt=""
data:image/s3,"s3://crabby-images/09d58/09d58bc605940fcf84e7c6eb64868dace4eeba79" alt=""
Completed Message Flowdata:image/s3,"s3://crabby-images/d24f6/d24f6dbc39ebb1d23d060b143f894b0e3b92b055" alt=""
เป็นอันเสร็จสิ้น จากนั้นลองทดสอบด้วย payload
<cop:CopyEmployeeRequest xmlns:cop="http://www.soabpm-vm.com/SOATrainingSamples/TransactionalInsert/xsd/CopyEmployeeService">
<!--Zero or more repetitions:-->
<cop:CopyEmployeeRequestInput>
<cop:EMP_FIRSTNAME>Austin</cop:EMP_FIRSTNAME>
<cop:EMP_SURNAME>Power</cop:EMP_SURNAME>
<cop:OU_ID>11</cop:OU_ID>
<cop:BIRTH_DATE>2008-09-28T18:49:45</cop:BIRTH_DATE>
<cop:NATIONAL_ID>2222222222222</cop:NATIONAL_ID>
</cop:CopyEmployeeRequestInput>
</cop:CopyEmployeeRequest>
|
================
Good Luck.
================