Archiving in SAP for Developers
Archiving is using program or archiving object .Archive data is also accessed using archiving information system Archive Information System (SAP AS) and DART (data retention tool)
In archiving all the records belongs to the archiving objects are written together to archive file and then deleted from database tables.
Data archiving process is composed of two steps
· Creation of archive files
· Deletion of data
Structure Definition: Describes which underlying tables are processed during data archiving.
How to fetch records from AS (Archive Info system )
Definition (AS) Archive Info system:
The Archive Information System (AS) is a generic tool for indexing data archives and is fully integrated into the SAP Data Archiving environment. The indexes created with this tool, which are called Archive Information Structures, are used to display archived data.
Get the archived info source SAP_BC_SBOOK01 go to tcode SARJ
The archiving object is a central component of SAP Data Archiving. The archiving object specifies precisely which data is archived and how. It describes which database objects must be handled together as a single business object. And interprets the data irrespective of the technical specifications at the time of archiving (such as release and hardware).
Ex:Go to SARE tcode :archiving Object BC_SBOOK.
There are two methods to fetch data from archive system.
When we need read one tables or when we need records from different tables.
Case 1: when we need to fetch records from AS table SBOOK only.
In this case we have Archive Object BC_SBOOK and we need records from only one table ie SBOOK.
We will use direct fetch method as below:
Direct fetch from AIS info objects
There is mapping table aind_str2 with AIS name
DATA :lv_arch_ind TYPE aind_fcat VALUE 'SAP_BC_SBOOK01'."Airchive info source name
Data:lv_gen_tab TYPE aind_str2-gentab.
*get the generated archive table generated
SELECT SINGLE gentab INTO lv_gen_tab
FROM aind_str2
WHERE archindex = lv_arch_ind
AND active = abap_true.
IF sy-subrc EQ 0.
*use same selection criteria for live data as well as archive data
SELECT *
APPENDING CORRESPONDING FIELDS OF TABLE gt_SFLIGHT
FROM (lv_gen_tab)
WHERE CARRID = 'A'
IF sy-subrc EQ 0.
ENDIF.
ENDIF.
Case 2: When we need to fetch data from All the three tables SBOOK,UDM_P2P_ATTR and USMCASEATTR00.Use FM 'ARCHIVE_GET_NEXT_RECORD' and filter the data based on the tables.
Sample program to fetch data from archive system using function module
DATA :g_sel TYPE rsds_frange_t.
DATA: ls_sel TYPE rsds_frange.
DATA :
gr_alv TYPE REF TO cl_salv_table,
gr_columns TYPE REF TO cl_salv_columns_table.
DATA : ra_selopt TYPE rsdsselopt .
DATA : lt_selopt TYPE STANDARD TABLE OF rsdsselopt .
DATA:
BEGIN OF g_sbook,
carrid LIKE sbook-carrid,
bookid LIKE sbook-bookid,
END OF g_sbook,
gt_result TYPE TABLE OF aind_arkey.
DATA :ls_result TYPE aind_arkey.
DATA :lv_handle TYPE sy-tabix.
DATA :lv_length TYPE i.
DATA :ls_record TYPE sbook.
DATA :ls_structure TYPE arc_buffer-rname.
DATA :gt_alv TYPE STANDARD TABLE OF sbook.
SELECTION-SCREEN : BEGIN OF BLOCK b1 WITH FRAME TITLE text-001.
PARAMETERS :carrid TYPE sbook-carrid.
PARAMETER :bookid TYPE sbook-bookid.
PARAMETERS:c_cb1 AS CHECKBOX.
PARAMETERS :c_cb2 AS CHECKBOX.
SELECTION-SCREEN : END OF BLOCK b1.
g_sbook-carrid = carrid.
g_sbook-bookid = bookid.
ra_selopt-sign = 'I'.
ra_selopt-option = 'EQ'.
ra_selopt-low = carrid.
APPEND ra_selopt TO lt_selopt.
g_sbook-carrid = carrid.
g_sbook-bookid = bookid.
ra_selopt-sign = 'I'.
ra_selopt-option = 'EQ'.
ra_selopt-low = bookid.
APPEND ra_selopt TO lt_selopt.
ls_sel-fieldname = 'CARRID'.
ls_sel-selopt_t = lt_selopt.
APPEND ls_sel TO g_sel.
CLEAR ls_sel.
CALL FUNCTION 'AS_API_READ'
EXPORTING
i_fieldcat = 'SAP_BC_SBOOK01'"Field catalog name
i_selections = g_sel
IMPORTING
e_result = gt_result.
IF sy-subrc = 0.
READ TABLE gt_result INTO ls_result INDEX 1.
CALL FUNCTION 'ARCHIVE_READ_OBJECT'
EXPORTING
object = 'BC_SBOOK'
archivkey = ls_result-archivekey
offset = ls_result-archiveofs
IMPORTING
archive_handle = lv_handle
compr_object_length = lv_length
EXCEPTIONS
no_record_found = 1
file_io_error = 2
internal_error = 3
open_error = 4
cancelled_by_user = 5
archivelink_error = 6
object_not_found = 7
filename_creation_failure = 8
file_already_open = 9
not_authorized = 10
file_not_found = 11
OTHERS = 12.
IF sy-subrc <> 0.
* Implement suitable error handling here
ENDIF.
ENDIF.
CALL FUNCTION 'ARCHIVE_GET_NEXT_RECORD'
EXPORTING
archive_handle = lv_handle
get_real_structure_name = lv_length
IMPORTING
record = ls_record
record_structure = ls_structure
EXCEPTIONS
end_of_object = 1
internal_error = 2
wrong_access_to_archive = 3
OTHERS = 4.
IF sy-subrc <> 0.
* Implement suitable error handling here
ENDIF.
*Display alv
If ls_structure eq 'SFLIGHT'
APPEND ls_record TO gt_alv.
CLEAR ls_record.
Else ls_structure eq ' UDM_P2P_ATTR '
APPEND ls_record_2 TO gt_alv2.
CLEAR ls_record_2.
Endif.
*This id for GT_ALV
CALL METHOD cl_salv_table=>factory
IMPORTING
r_salv_table = gr_alv
CHANGING
t_table = gt_alv.
gr_columns = gr_alv->get_columns( ).
CALL METHOD gr_alv->display.
Mình đã tìm thấy các thông tin cần thiết ở đây, cảm ơn bạn. Mình cũng muốn giới thiệu về một Công ty dịch thuật uy tín - Công ty dịch thuật miền trung - MIDtrans có trụ sở chính chính tại địa chỉ 02 Hoàng Diệu, TP Đồng Hới, tỉnh Quảng Bình có Giấy phép kinh doanh số 3101023866 cấp ngày 9/12/2016 là đơn vị chuyên cung cấp dịch vụ dịch thuật, phiên dịch dành các cá nhân. Hệ thống thương hiệu và các Công ty dịch thuật con trực thuộc: công ty dịch thuật hcm - dịch thuật sài gòn 247 , địa chỉ 47 Điện Biên Phủ, Phường Đakao, Quận 1 TP HCM, dịch thuật buôn mê thuột, đăk lăk : địa chỉ 100 , Lê lợi, TP Buôn Mê Thuột là nhà cung ứng dịch vụ dịch thuật uy tín hàng đầu tại Đăk Lăk; vietnamese translation : dịch vụ dịch thuật cho người nước ngoài có nhu cầu, giao diện tiếng Anh dễ sử dụng; dịch thuật công chứng gò vấp : nhà cung ứng dịch vụ dịch vụ dịch thuật phiên dịch hàng đầu tại Quận Bình Thạnh, TP HCM; dịch thuật đà nẵng : Địa chỉ 54 Đinh Tiên Hoàng, Quận Hải Châu, TP Đà Nẵng chuyên cung cấp dịch vụ dịch thuật công chứng, dịch thuật chuyên ngành tại Đà Nẵng; dịch thuật hà nội midtrans : địa chỉ 101 Láng Hạ, Đống Đa, Hà Nội là nhà cung ứng dịch vụ biên dịch, phiên dịch chuyên nghiệp tại địa bàn Hà Nội. Chúng tôi chuyên cung cấp các dịch vụ biên dịch và phiên dịch, dịch thuật công chứng chất lượng cao hơn 50 ngôn ngữ khác nhau như tiếng Anh, Nhật, Hàn, Trung, Pháp, Đức, Nga, Tây Ban Nha, Bồ Đào Nha, Ý, Ba Lan, Phần Lan, Thái Lan, Hà Lan, Rumani, Lào, Campuchia, Philippin, Indonesia, La Tinh, Thụy Điển, Malaysia, Thổ Nhĩ Kỳ..vv... Dịch thuật MIDtrans tự hào với đội ngũ lãnh đạo với niềm đam mê, khát khao vươn tầm cao trong lĩnh vực dịch thuật, đội ngũ nhân sự cống hiến và luôn sẵn sàng cháy hết mình. Chúng tôi phục vụ từ sự tậm tâm và cố gắng từ trái tim những người dịch giả.Tự hào là công ty cung cấp dịch thuật chuyên ngành hàng đầu với các đối tác lớn tại Việt nam trong các chuyên ngành hẹp như: y dược (bao gồm bệnh lý), xây dựng (kiến trúc), hóa chất, thủy nhiệt điện, ngân hàng, tài chính, kế toán. Các dự án đã triển khai của Công ty dịch thuật chuyên nghiệp MIDtrans đều được Khách hàng đánh giá cao và đạt được sự tín nhiệm về chất lượng biên phiên dịch đặc biệt đối với dịch hồ sơ thầu , dịch thuật tài liệu tài chính ngân hàng, dịch thuật tài liệu y khoa đa ngữ chuyên sâu. Đó là kết quả của một hệ thống quản lý chất lượng dịch thuật chuyên nghiệp, những tâm huyết và kinh nghiệm biên phiên dịch nhiều năm của đội ngũ dịch giả của chúng tôi. Hotline: 0947688883. email: info@dichthuatmientrung.com.vn . Các bạn ghé thăm site ủng hộ nhé. Cám ơn nhiều
ReplyDelete