ตัวอย่าง
- Mapping non-XML to XML
- อ่าน CSV file แล้ว Insert เข้า Database (File transport - Proxy Service)
- ส่ง Payload เป็น CSV แล้ว insert เข้า Database
- Mapping XML to non-XML
- Query database แล้ว save เป็น CSV file (File transport - Business Service)
ก่อนตัวอย่างทั้งหมด ให้สร้าง MFL file (Mapping file คล้าย XSL กับ XQ)
From
|
To
|
File name
|
non-XML
|
XML
|
EmployeeMessageFormat.mfl
|
XML
|
non-XML
|
EmployeeMessageFormat.mfl
|
** ในตัวอย่างสามารถใช้ file เดียวกันได้เลย
OEPE:
1) New MFL…data:image/s3,"s3://crabby-images/a930d/a930d2b44aaa821f77e7f61f660ca9d20ad13063" alt=""
data:image/s3,"s3://crabby-images/78fdc/78fdc5734caa666e86d893378f6abb0f879fefc6" alt=""
แก้ XML document encoding เป็น UTF-8data:image/s3,"s3://crabby-images/08c31/08c315c77115e8ce5b540de414a7ba66c653e164" alt=""
data:image/s3,"s3://crabby-images/87288/872880722fb230423320f3f30a49fb0ed7f14fc1" alt=""
2) เพิ่มกลุ่มของ message เพราะอาจส่งข้อมูล Employee มากกว่า 1 คนdata:image/s3,"s3://crabby-images/679ba/679ba5f17bb605d116931bbf7d7707e93b680122" alt=""
data:image/s3,"s3://crabby-images/0fc97/0fc9795d4af715d3577981a7476ba38db699fbdd" alt=""
3) เพิ่ม Fields ที่ต้องใช้ได้แก่
a) field name ‘title’ ระบุเป็น Child ของ Groupdata:image/s3,"s3://crabby-images/83765/8376523352b12343f57e6d9fc46a0b2736673a60" alt=""
b) field name ‘firstname’data:image/s3,"s3://crabby-images/4c6c1/4c6c10ed05a94962d4d550db21500791667310da" alt=""
data:image/s3,"s3://crabby-images/24778/247781a757c78591307e38c56a0c5f12f9bda6f4" alt=""
c) field name ‘surname’data:image/s3,"s3://crabby-images/7157e/7157e86026fd997ba87635581f68a28e5ae2b05f" alt=""
d) field name ‘ouid’data:image/s3,"s3://crabby-images/a9a94/a9a94081ff22d6b506dbfe57f8273b14871e6e61" alt=""
e) field name ‘birthdate’data:image/s3,"s3://crabby-images/20006/200063dac291684fe97db08f63419dd7f2971504" alt=""
f) field name ‘nationid’ ซึ่งเป็น field สุดท้าย ให้ปิดท้ายด้วย \n (ขึ้นบรรทัดใหม่)data:image/s3,"s3://crabby-images/bbb88/bbb88fdc743928ac1e840a4053a5bb83c37bfb5a" alt=""
4) ทดสอบ MFL transformation ด้วย CSV
**** ข้อควรระวัง บรรทัดสุดท้ายต้องเป็นบรรทัดว่าง ด้วยการกด ENTER ไม่เช่นนั้นจะไม่สามารถ Transform CSV นั้นได้
นาย;สมชาย;แซ่ลี้;10;2013-09-16T18:01:33;1112222233333
นาง;สมศรี;วงศ์ไทย;10;2013-09-16T18:04:55;2112222233333
นาย;สมศักดิ์;จันดี;10;2013-09-16T18:09:01;3112222233333
นาง;สมหญิง;เก่งงาน;10;2013-09-16T18:13:10;4112222233333
|
กรณีไม่ \n หรือมีมากกว่า 1 จะเกิด Errordata:image/s3,"s3://crabby-images/1272d/1272dbdf10f09fe471ffb554b3055b34183f2e51" alt=""
หลังจากได้ MFL file แล้วให้สร้าง XQuery transformation
สำหรับตัวอย่างที่ 1 อ่าน CSV file แล้ว Insert เข้า Database
Source
|
Target
|
File name
|
EmployeeMessageFormat
|
MergeEmployeeService1
|
EmployeeMessageFormat_To_MergeEmployeeService1.xq
|
สำหรับตัวอย่าง 3 Query database แล้ว save เป็น CSV file
Source
|
Target
|
File name
|
QueryEmployeeService1
|
EmployeeMessageFormat
|
QueryEmployeeService1_To_EmployeeMessageFormat.xq
|
WriteCSVService1
|
QueryEmployee
|
WriteCSVService1_To_QueryEmployee.xq
|
OEPE:
EmployeeMessageFormat_To_MergeEmployeeService1.xq
(:: pragma bea:mfl-element-parameter parameter="$employeeMessageFormat1" type="EmployeeMessageFormat@" location="../mfl/EmployeeMessageFormat.mfl" ::)
(:: pragma bea:global-element-return element="ns0:EmployeeBakCollection" location="../../Adapter/xsd/MergeEmployeeService1_table.xsd" ::)
declare namespace ns0 = "http://xmlns.oracle.com/pcbpel/adapter/db/top/MergeEmployeeService1";
declare namespace xf = "http://tempuri.org/DatabaseTX1/Service/xq/EmployeeMessageFormat_To_MergeEmployeeService1/";
declare namespace funcSQL = "http://www.v-smart.com/function/xq/funcSQL";
declare function funcSQL:nextVal() as xs:decimal {
let $val := fn-bea:execute-sql('jdbc/OSBDemoXE','value','SELECT EMP_SEQ.NEXTVAL FROM DUAL')
return $val
};
declare function xf:EmployeeMessageFormat_To_MergeEmployeeService1($employeeMessageFormat1 as element())
as element(ns0:EmployeeBakCollection) {
<ns0:EmployeeBakCollection>
{
for $Employee in $employeeMessageFormat1/Employee
return
<ns0:EmployeeBak>
<ns0:id>{ funcSQL:nextVal() }</ns0:id>
<ns0:firstname>{ data($Employee/firstname) }</ns0:firstname>
<ns0:surname>{ data($Employee/surname) }</ns0:surname>
<ns0:ouId>{ xs:decimal($Employee/ouid/text()) }</ns0:ouId>
<ns0:birthDate>{ xs:dateTime($Employee/birthdate/text()) }</ns0:birthDate>
<ns0:nationalId>{ data($Employee/nationid) }</ns0:nationalId>
</ns0:EmployeeBak>
}
</ns0:EmployeeBakCollection>
};
declare variable $employeeMessageFormat1 as element() external;
xf:EmployeeMessageFormat_To_MergeEmployeeService1($employeeMessageFormat1)
|
QueryEmployeeService1_To_EmployeeMessageFormat.xq
(:: pragma bea:global-element-parameter parameter="$queryEmployeeService1OutputCollection1" element="ns0:QueryEmployeeService1OutputCollection" location="../../Adapter/xsd/QueryEmployeeService1.xsd" ::)
(:: pragma bea:mfl-element-return type="EmployeeMessageFormat@" location="../mfl/EmployeeMessageFormat.mfl" ::)
declare namespace ns0 = "http://xmlns.oracle.com/pcbpel/adapter/db/QueryEmployeeService1";
declare namespace xf = "http://tempuri.org/DatabaseTX1/Service/xq/QueryEmployeeService1_To_EmployeeMessageFormat/";
declare function xf:QueryEmployeeService1_To_EmployeeMessageFormat($queryEmployeeService1OutputCollection1 as element(ns0:QueryEmployeeService1OutputCollection))
as element() {
<EmployeeMessageFormat>
{
for $QueryEmployeeService1Output in $queryEmployeeService1OutputCollection1/ns0:QueryEmployeeService1Output
return
<Employee>
<title/>
<firstname>{ data($QueryEmployeeService1Output/ns0:EMP_FIRSTNAME) }</firstname>
<surname>{ data($QueryEmployeeService1Output/ns0:EMP_SURNAME) }</surname>
<ouid>{ xs:string($QueryEmployeeService1Output/ns0:OU_ID) }</ouid>
<birthdate>{ xs:string($QueryEmployeeService1Output/ns0:BIRTH_DATE) }</birthdate>
<nationid>{ data($QueryEmployeeService1Output/ns0:NATIONAL_ID) }</nationid>
</Employee>
}
</EmployeeMessageFormat>
};
declare variable $queryEmployeeService1OutputCollection1 as element(ns0:QueryEmployeeService1OutputCollection) external;
xf:QueryEmployeeService1_To_EmployeeMessageFormat($queryEmployeeService1OutputCollection1)
|
WriteCSVService1_To_QueryEmployee.xq
xquery version "1.0" encoding "Cp1252";
(:: pragma parameter="$anyType1" type="xs:anyType" ::)
(:: pragma bea:global-element-return element="ns0:QueryEmployeeService1Input" location="../../Adapter/xsd/QueryEmployeeService1.xsd" ::)
declare namespace xf = "http://tempuri.org/DatabaseTX1/Service/xq/WriteCSVService1_To_QueryEmployee/";
declare namespace ns0 = "http://xmlns.oracle.com/pcbpel/adapter/db/QueryEmployeeService1";
declare function xf:WriteCSVService1_To_QueryEmployee($anyType1 as element(*))
as element(ns0:QueryEmployeeService1Input) {
<ns0:QueryEmployeeService1Input/>
};
declare variable $anyType1 as element(*) external;
xf:WriteCSVService1_To_QueryEmployee($anyType1)
|
*********** เริ่มต้น
ตัวอย่างที่ 1 อ่าน CSV file แล้ว Insert เข้า Database
สร้าง Proxy Service และกำหนดให้ Proxy service อ่าน CSV file จาก disk เพื่อนำมาเป็น Inbound ของ Service
แก้ไข default Service type เป็น Message Servicedata:image/s3,"s3://crabby-images/d1db1/d1db1f75927fbf71de9081679ae12d1882510b89" alt=""
แก้ไขเป็น Textdata:image/s3,"s3://crabby-images/3b000/3b000f7476dff2725cb9f9dbb6de584c34e96ba5" alt=""
แก้ไข Protocol = file และกำหนด Endpoint เป็น Directory เก็บ CSV filedata:image/s3,"s3://crabby-images/f6e47/f6e47ebbdfb64d4327608e3b404a516623f888c3" alt=""
กำหนด
File mask = *.csv (filter ชื่อ file ต่อท้ายด้วย .csv)
Polling interval = 10 (อ่าน file จาก Directory ทุกๆ 10 วินาที)
Read limit = 1 (หากเจอ file มากกว่า 1 file จะเปิดอ่านที่ละ file)
Uncheck Sort By Arrival (ให้อ่าน file ที่มาก่อนหรือไม่)
Post Read Action = archive (หากอ่าน file เสร็จให้ move ไปที่ Archive Directory)
Request Encoding = UTF-8 (default)
จากนั้นระบุ Stage, Archive และ Error Directorydata:image/s3,"s3://crabby-images/dcc97/dcc9775a31125da4000ec1a9985e3e2232c5801d" alt=""
สร้าง Message Flowdata:image/s3,"s3://crabby-images/f8db8/f8db810a4ef5dafdccb5926dd4e00642f11ffbe0" alt=""
Transform_To_XML stagedata:image/s3,"s3://crabby-images/9cf5d/9cf5dd618ed07a27fc84e3dd66cb02a19a0b9739" alt=""
Inside stagedata:image/s3,"s3://crabby-images/47eae/47eae10131e9adf05f15d271ce7ff4636ebb325e" alt=""
data:image/s3,"s3://crabby-images/d3deb/d3deb1b97e940a13a5f66d09431e9b4fbf1a16d5" alt=""
Merge stage หรือ Insert เข้า Databasedata:image/s3,"s3://crabby-images/7dd66/7dd66a690b277c17db861628944489456ad8372d" alt=""
Inside stagedata:image/s3,"s3://crabby-images/d3b66/d3b66b4dcf8c3e0fb50df2b39a27f5e875a2330e" alt=""
data:image/s3,"s3://crabby-images/e7b1e/e7b1ed112395d1710b9757eb0fe9c6520c93c019" alt=""
data:image/s3,"s3://crabby-images/85152/85152dbc5a295b4c1f39c9bcd14d3bb8fbcf35e3" alt=""
data:image/s3,"s3://crabby-images/12eec/12eecda4320e670cd7eb4fe65985e3dd1a167e3d" alt=""
data:image/s3,"s3://crabby-images/ce420/ce42034770a56543a9fb44224b6933c188cd47d2" alt=""
data:image/s3,"s3://crabby-images/03250/032502afd5f977126eee5e97c9c49851b96ed94c" alt=""
Completed Message Flowdata:image/s3,"s3://crabby-images/a651e/a651e1b3821b9bbb04712f399985f3de4ccc00bb" alt=""
ตัวอย่างที่ 2 ส่ง Payload เป็น CSV format แล้ว insert เข้า Database
สร้าง Proxy Service กำหนดให้รับ XML Payload ที่มี Value เป็น CSV string ตัวอย่าง Payload ที่ใช้ในการทดสอบ ได้แก่
<employee>นาย;สมชาย;แซ่ลี้;10;2013-09-16T18:01:33;1112222233333
นาง;สมศรี;วงศ์ไทย;10;2013-09-16T18:04:55;2112222233333
นาย;สมศักดิ์;จันดี;10;2013-09-16T18:09:01;3112222233333
นาง;สมหญิง;เก่งงาน;10;2013-09-16T18:13:10;4112222233333
</employee>
|
Transform_To_XML1 stagedata:image/s3,"s3://crabby-images/1505d/1505dcfb23cc793e7ba71b2dc17c7264b1ad20f5" alt=""
Inside stage
*** Recommendation: OSB treats "$body/*[1]" as a special XPath that can be evaluated without invoking the XQuery engine. This is faster than specifying an absolute path pointing to the child of $body. A general XPath like "$body/Order" must be evaluated by the XQuery engine before the primary transformation resource is executed.
Merge1 stage จะเหมือนกับ Merge stage ในตัวอย่างที่ 1 เพราะมันจะต่างแค่ Stage ที่รับ Inbound และ MFL เท่านั้นdata:image/s3,"s3://crabby-images/677d0/677d0c27688ec5c6339e7b2032c52e79afbad27a" alt=""
ตัวอย่างที่ 3 Query database แล้ว save เป็น CSV file
ก่อนอื่นให้สร้าง Business Service สำหรับ Write file operation ก่อนdata:image/s3,"s3://crabby-images/12595/125954fd2c157cfd57c2b2671f444a28a609bd07" alt=""
data:image/s3,"s3://crabby-images/c4b58/c4b58f04f26fd366f607834b5c2dc1476f58101c" alt=""
data:image/s3,"s3://crabby-images/e1d88/e1d88e1dd0a886826e05cb8712f74d4e92d7bd17" alt=""
data:image/s3,"s3://crabby-images/2d6e9/2d6e9e1a2e3211ca5a3aaed069a9ccd4de7c6592" alt=""
สร้าง Proxy Service กำหนดให้ Query Database แล้ว Save เป็น CSV file ลง Diskdata:image/s3,"s3://crabby-images/1b814/1b8142a5122cbd4e556928df016b878c31d2f2c7" alt=""
data:image/s3,"s3://crabby-images/627a7/627a7dd462da76976bb577735ce2bbf6425f243f" alt=""
data:image/s3,"s3://crabby-images/b553e/b553e175eda7ade51102ec10a578dfe66aef5205" alt=""
QueryEmployee Stagedata:image/s3,"s3://crabby-images/4617e/4617eb92d100661e3fe96456bd8a9cbe232f76d4" alt=""
Inside stagedata:image/s3,"s3://crabby-images/1b4e2/1b4e2c1e2152e1a1ce154dbe527a544de7bed23b" alt=""
data:image/s3,"s3://crabby-images/6d552/6d5525dda483e77b1010dd424adb527e08e185b5" alt=""
data:image/s3,"s3://crabby-images/0b980/0b98062ef526b5c96f6dfdaa08ca3c2136eec81a" alt=""
data:image/s3,"s3://crabby-images/1c835/1c83577a8639a8be308f425f45ecb15582730a7f" alt=""
Transform_To_CSV stagedata:image/s3,"s3://crabby-images/cd8e4/cd8e498197f2763e532d19af798391e7851bb826" alt=""
Inside stagedata:image/s3,"s3://crabby-images/fb00c/fb00ce89e2b87a10bd25bb1e7b79152e239e5805" alt=""
data:image/s3,"s3://crabby-images/faad6/faad67d7addbd54873bf81b87ab6da21959581da" alt=""
WriteCSVFile stagedata:image/s3,"s3://crabby-images/41b11/41b11fb53baefc6b64aabb4f2fb691c7678bc1c5" alt=""
Inside stagedata:image/s3,"s3://crabby-images/d6c8c/d6c8c2a60d97385bccf809be90dd490d26dd37c3" alt=""
data:image/s3,"s3://crabby-images/37bf5/37bf549b9b1a6317c8d2122f4501a3d4d59ab272" alt=""
data:image/s3,"s3://crabby-images/4e19e/4e19e5139d573f96ee42505e9eb8ed685625559d" alt=""
Completed Message Flowdata:image/s3,"s3://crabby-images/cc9ff/cc9ff9ce96e6450d22cb76c9bfcc9040127acfb7" alt=""
ตัวอย่าง Output file คือ
test2013-09-17T10:07:00.407-07:00.txt