|
| 1 | +CLASS zcl_generate_demo_data_#### DEFINITION |
| 2 | + PUBLIC |
| 3 | + FINAL |
| 4 | + CREATE PUBLIC . |
| 5 | + |
| 6 | + PUBLIC SECTION. |
| 7 | + INTERFACES if_oo_adt_classrun. |
| 8 | + PROTECTED SECTION. |
| 9 | + PRIVATE SECTION. |
| 10 | +ENDCLASS. |
| 11 | + |
| 12 | +CLASS zcl_generate_demo_data_#### IMPLEMENTATION. |
| 13 | + METHOD if_oo_adt_classrun~main. |
| 14 | + |
| 15 | + " delete existing entries in the database table |
| 16 | + DELETE FROM zrap_atrav_####. |
| 17 | + DELETE FROM zrap_abook_####. |
| 18 | + |
| 19 | + " insert travel demo data |
| 20 | + INSERT zrap_atrav_#### FROM ( |
| 21 | + SELECT |
| 22 | + FROM /dmo/travel |
| 23 | + FIELDS |
| 24 | + uuid( ) AS travel_uuid , |
| 25 | + travel_id AS travel_id , |
| 26 | + agency_id AS agency_id , |
| 27 | + customer_id AS customer_id , |
| 28 | + begin_date AS begin_date , |
| 29 | + end_date AS end_date , |
| 30 | + booking_fee AS booking_fee , |
| 31 | + total_price AS total_price , |
| 32 | + currency_code AS currency_code , |
| 33 | + description AS description , |
| 34 | + CASE status |
| 35 | + WHEN 'B' THEN 'A' " accepted |
| 36 | + WHEN 'X' THEN 'X' " cancelled |
| 37 | + ELSE 'O' " open |
| 38 | + END AS overall_status , |
| 39 | + createdby AS created_by , |
| 40 | + createdat AS created_at , |
| 41 | + lastchangedby AS last_changed_by , |
| 42 | + lastchangedat AS last_changed_at , |
| 43 | + lastchangedat AS local_last_changed_at |
| 44 | + ORDER BY travel_id UP TO 200 ROWS |
| 45 | + ). |
| 46 | + COMMIT WORK. |
| 47 | + |
| 48 | + " insert booking demo data |
| 49 | + INSERT zrap_abook_#### FROM ( |
| 50 | + SELECT |
| 51 | + FROM /dmo/booking AS booking |
| 52 | + JOIN zrap_atrav_#### AS z |
| 53 | + ON booking~travel_id = z~travel_id |
| 54 | + FIELDS |
| 55 | + uuid( ) AS booking_uuid , |
| 56 | + z~travel_uuid AS travel_uuid , |
| 57 | + booking~booking_id AS booking_id , |
| 58 | + booking~booking_date AS booking_date , |
| 59 | + booking~customer_id AS customer_id , |
| 60 | + booking~carrier_id AS carrier_id , |
| 61 | + booking~connection_id AS connection_id , |
| 62 | + booking~flight_date AS flight_date , |
| 63 | + booking~flight_price AS flight_price , |
| 64 | + booking~currency_code AS currency_code , |
| 65 | + z~created_by AS created_by , |
| 66 | + z~last_changed_by AS last_changed_by , |
| 67 | + z~last_changed_at AS local_last_changed_by |
| 68 | + ). |
| 69 | + COMMIT WORK. |
| 70 | + |
| 71 | + out->write( 'Travel and booking demo data inserted.'). |
| 72 | + ENDMETHOD. |
| 73 | + |
| 74 | +ENDCLASS. |
0 commit comments