반응형

SAP 97

Call Transaction 권한 체크

Call Transaction 은 프로그램 상에서 tcode를 호출하는데 많이 사용된다. 그런데 이게 문제가 있는게 시스템상에 권한을 등록해도 프로그램 실행 권한이 있다면 그냥 무시하고 tcode 를 실행해버리는 단점이 있다. 그래서 Call Transaction 에 권한 체크 기능이 필요하다면 아래와 같은 Standard Function 을 사용하면 된다. FORM call_transaction USING tcode. DATA : l_tcode LIKE tstc-tcode. CLEAR l_tcode. l_tcode = tcode. CALL FUNCTION 'AUTHORITY_CHECK_TCODE' EXPORTING tcode = l_tcode EXCEPTIONS ok = 1 not_ok = 2 OTHE..

SAP/Function 2014.07.29

ABAP 개발 중 성능에 대한 고민

오늘은 ABAP 개발 성능에 대한 고민에 대해서 이야기 해 보려고 한다. SAP 는 다른 일반 개발보다 조금은 다른 점이 있다. 회사의 기간계 시스템이다 보니 조금 느리게 프로그램이 돌아도 데이터가 많아서 그러려니 하면서 사용자들이 기다려준다는 것이다. 웹의 경우 3초 안에 안 나오면 다른 곳으로 옮긴다는 통계도 예전에 본적이 있다. 뭐 요즘은 인터넷 회선도 빠르고 서버도 좋고 좋고 빠른 라이브러리들도 많아서 성능이 엄청 올라가긴 했다. 그러나 최근 성능 개선 요구를 받고 있다. 처음 짜 놓은 프로그램이 10만건 정도를 루프를 돌리면서 Collect 를 하고, 필요한 데이터를 Internal Table 에 채워 넣었다. 그런데 이게 너무 느리다는 것이다. 내가 봐도 느리긴 했다. 그런데 성능 개선이라는게..

SAP 2014.07.29

Table 조회시 Day, Select 시 TAG 으로 나오는 경우

오늘도 개발을 하다가 희안한 상황을 발견하였다. 상황의 내용은 단위가 Day 인데 TAG 으로 나오는 것이다. TAG 은 독일어로 "일" 을 의미하니 DAY 와 동일한 의미이긴 하다. 그래서 TAG도 DAY 로 처리해서 개발하면 되는데, 희안 하다고 해야 할지 아니면 SAP가 꼼꼼하다고 해야 할지 아무튼 상황이 제목과 같은 상황이 발생하였다. SE11 을 사용하여 테이블을 조회하면 실제로 DAY 라는 데이터가 보인다. 그런데 프로그램 상에서 사용하려고 Select 를 할 경우에는 TAG 이라고 조회가 된다. 그렇다고 별도의 테이블에 Language 코드가 있는 것도 아니었다. [ SE11 로 조회하는경우 ] [ 프로그램 상에서 Select 한 경우 ] 나는 Table 을 살펴보던중 도메인에 옵션이 걸려 ..

SAP/Function 2014.07.28

ABAP 정규표현식을 사용한 사번체크

프로그램을 개발하는 도중에 사번을 체크 할 일이 생겼다. 사번이 특별한 형태로 이루어져 있기 때문에 어떻게 쉽게 체크 할 수 없을까 고민 끝에 정규표현식을 사용해 보기로 했다. 기존에 웹 개발을 했을 때도 가끔 사용하기도 했는데 이게 생각보다 간단한것 같지만 이해도 잘 안돼서 망한 경우도 많이 있었다. ㅎㅎ 오늘의 사번 형태는 AB + 숫자 6자리인 형태인 사번을 체크하는 로직이다. 앞에 AB 는 "AB로 시작하는" 의 의미이다. 그리고 [0-9] 는 "0~9 사이의 숫자가 들어 올 수 있다는" 의미이고 {6} 은 "6자리를 의미"한다. 간단하게 예제소스를 돌려보면 abap_true 값인 'X' 값이 출력 되는 것을 알 수 있다. REPORT ytest_regex. DATA : lr_matcher TYP..

SAP/ABAP 2014.07.24

ABAP Dynamic Internal Table 을 Read Table 하기

최근 Dynamic Internal Table 을 이용한 프로그램을 많이 만들었다. ( 된장찌게 엄청 빡세고 내용만 엄청 길어져서 다 갈아내고 싶다. ) 이전에 Dynamic Internal Table 을 생성하는 포스팅을 했었다. [SAP/ABAP] - 동적 인터널 테이블을 만들때 deep structure 로 생성하기 그런데 프로그램을 개발하도 보니 Internal Table 의 최대 장점인 Read Table 을 사용하기에 애매한 부분이 생겼다. 그냥 선언해서 사용하는 Internal Table 의 경우 Field 명을 그냥 with key Field = 'XXX' 이런식으로 사용이 가능한데 Dynamic 하게 생성한 Internal Table 은 Field 자체를 고정 할 수 없어서 with Ke..

SAP/ABAP 2014.07.16

Variant 없이 Batch Job 생성하기 ( Dummy Variant 생성 )

오늘의 특이 케이스는 Batch Job을 생성하는 과정에서 나타나는 오류는 아니지만 엉뚱한 곳에서 문제가 생긴 케이스 이다. 이 포스팅 이전에 Variant 와 Batch Job 에 대해 포스팅을 3차례 하였는데 이 케이스는 없는 것 같아 추가적으로 기록을 남기게 되었다. Batch Job 을 등록하는데 Variant를 넣으라고 하는 메시지를 내보내고 진행이 안된다. 는 질문을 받았다. 그런데 다른 Job 들을 보니 Variant 없이 등록된 Job 들도 있었고, 그래서 왜 안되냐고 잘해보라고 닥달(?)을 하고 나서 나도 실제로 SM36을 통해서 배치잡을 등록하다보니 안되는 것이었다. (살짝 미안했다. ) [SAP/Scrap] - 스케쥴 백그라운 작업 생성 ( Batch Job ) [SAP/ABAP] -..

SAP/ABAP 2014.07.16

ABAP Report Dynamic Variant 만들기

이전에 Report 에 Variant (변형) 을 생성하는 방법을 포스팅 한 적이 있다. 오늘은 이 variant 를 dynamic 하게 생성하는 방법을 포스팅하고자 한다. [SAP/ABAP] - Report 프로그램 변형 ( Variant ) 그런데 Dynamic Variant 는 Date 만 가능한 것 같다. 심지어 연월 필드도 되지 않는다. 하지만 batch job 의 경우 대부분 일자를 기준으로 작업을 돌리기 때문에 큰 문제는 없는 것 같다. 다른 방법을 발견하게 된다면 추가해야겠다. 1. 일단 이전에 변형을 생성하는 것과 같다. SAVE 버튼을 눌러서 Variant 생성 화면으로 이동한다. 2. Variant Attributes 에서 Selection Variable Option 을 선택한다. ..

SAP/ABAP 2014.07.11

FI 모듈의 기본 테이블 정보

FI 모듈의 고전적적인 테이블 그림이다. 누가 만드셨는지 참 훌륭하다. 아래의 내요을 보면 테이블 간의 구조를 쉽게 알 수 있다. * 임시전표 관련 테이블 - VBKPF : 임시테이블의 전표 HEAD. - VBSEGA : 자산관련 임시전표의 ITEM . - VBSEGD : 고객관련 임시전표의 ITEM. - VBSEGK : 구매처관련 임시전표의 ITEM. - VBSEGS : G/L관련 임시전표의 ITEM. * 실제 전표관련 테이블 - BKPF : 전표의 HEAD 테이블. - BSEG : 전표의 ITEM 레벨의 테이블로 인덱스가 없는 클러스터테이블로 구성되어 졌다. - BSET,BSED,BSES,BSEC 등은 ITEM 레벨의 세부항목들이 잇다.! - BSIS : G/L 계정의 미결항목을 관리하는 테이블.(반..

SAP 2014.07.11

Tcode 조회 사이트

SAP 개발하다보면 매번 사용하는 tcode 가 있다. 그런것은 손에 익어서 기억하겠지만 그 외에 많은 tcode 는 기억하기가 쉽지않다. tcode 를 찾다가 우연히 발견한 사이트를 소개하려고 한다. 이미 많은 분들이 즐겨찾기 해 놓고 쓰겠지만 그래도 유용한 사이트라고 생각되어 기록을 남긴다. (외쿸사이트 이지만 어려워하지 말자.. 쉽다..) http://www.tcodesearch.com/ 위 사이트는 온갖 tcode를 조회 할 수 있는 사이트 이다. 개발자라면 개발에 관련된 tcode 외에 모듈에 관련된 tcode 를 알아야 하는데 쉽게 찾을 수 있는 사이트이다. 검색해본 결과 꼭 tcode에 맞는 텍스트는 유사한 내용들이 계속 표시되니 금방 잘 찾아주는 것 같다. 이것을 즐겨찾기 해놓고 tcode..

SAP/ABAP 2014.07.03

ALV 엑셀 Export 시 데이터 분리 현상 해결방법

Class ALV 를 개발하고 나서 ALV 의 내용을 export 시키는 기본 기능을 많이 사용한다. 현업에서도 많이 사용하고 개발자들도 데이터를 내릴 때 많이 사용하는데 가끔 개발후 EXPORT > 로컬 파일 > 스프레드 시트 로 다운로드 받을 때 아래와 같은 현상이 발생한다. 그리드는 하나로 보이는데 데이터를 내리면 2개 이상으로 분리되어 보이는 경우가 있다. 이럴 때는 ALV 의 SORT 하는 부분의 속성을 확인하면 된다. *&---------------------------------------------------------------------* *& Form GRID_SET_SORT *&-----------------------------------------------------------..

SAP/ABAP 2014.07.03

특정 문자열 개수 세기

ABAP 개발중 String 에서 특정 문자의 개수를 세고 싶은 경우가 있다. 예를 들면 "ABCDABCDEFG" 에서 A의 개수는 몇개인지를 알고 싶을 때 사용하는 코드이다. REPORT ytest012. DATA : lv_string TYPE string, lv_cnt TYPE i. lv_string = 'ABCDABCDEFG'. FIND ALL OCCURRENCES OF 'A' IN lv_string MATCH COUNT lv_cnt. WRITE : lv_cnt. 또한 특정 문자 예를 들면 "A" 가 최초 어디 위치에 있는지를 알려주는 코드이다. FIND 'A' IN LV_STRING MATCH OFFSET LV_OFF.

SAP/ABAP 2014.06.30

ABAP Screen menu template

ABAP 레포트를 개발하다보면 스텐다드에 많은 메뉴를 기본으로 가지고 있는 것을 볼 수 있다. 하지만 개발자가 기본으로 개발하는 메뉴들은 각각 정의하여 사용한다. 그런데 종종 스텐다드에 보이는 아래와 같은 메뉴를 설정하고 싶을 때가 있다. 가령 예를 들면 Function ALV 를 사용한다던지 할 때 넣고 싶지만 너무 많아 넣지 못하는 경우가 있다. 그럴때 사용하라고 SAP에서는 템플릿을 제공한다. 메뉴 템플릿의 사용하는 방법을 알아보겠다. 메뉴를 처음 만들면 그냥 빈칸들만 있는 메뉴들이 만들어진다. 상단 메뉴에서 Extras > Adjust template 을 선택한다. 메뉴에서 List Viewer 를 선택한다. 그러면 처음 화면의 메뉴들이 다 들어와서 자리를 잡는다.Template Status 를 ..

SAP/ABAP 2014.06.16

ABAP File Upload

Abap 텍스트 파일을 업로드 하는 방법은 여러가지가 있다. 아래의 예제는 cl_gui_frontend_services=>gui_upload 를 사용한 예제이다. 이 외에도 Function Gui_upload 를 사용하는 방법이 있다. 둘의 차이는 잘 모르겠으나 거의 동일한 기능을 하는 것으로 생각된다. REPORT zfileupload MESSAGE-ID zfi. DATA : itab TYPE STANDARD TABLE OF string. PARAMETERS: p_file TYPE rlgrap-filename OBLIGATORY. AT SELECTION-SCREEN ON VALUE-REQUEST FOR p_file. CALL FUNCTION 'F4_FILENAME' IMPORTING file_name ..

SAP/ABAP 2014.06.16

BADI 생성 예제

Abap 개발중에 Standard 프로그램에 Exit 을 넣어야 하는 경우가 있다. 그냥 CBO 프로그램이라면 고치면 되겠지만 Standard 프로그램의 경우 막 고칠 수도 없을 뿐더러 나중에 notes 나 sp 가 올라갈 때 문제를 발생 시킬 수 가 있다. SAP 에서는 BADI 라고 하여 중간에 사용자가 개발한 로직을 넣을 수 있게 구멍(?)을 뚫어 놓았는데, 아래가 그것을 생성하는 예제이다. 아래 블로그를 통해 한번 쭉 따라 해보는 것도 좋을 것 같다. http://sarange.net/588 Related Posts[SAP_ABAP] - ABAP 소스 비교 프로그램[SAP_ABAP/Scrap] - Table Control (테이블 컨트롤) 예제 소스[SAP_WD4A] - Web dynpro 의 시..

SAP/스크랩 2014.05.17

Web dynpro 의 시작

Web Dynpro For ABAP 에도 한번 도전해 보고 싶다. SAP 를 웹으로 접속해서 사용하는게 User 입장에서는 좋을지도 모르겠다. 개발자 입장에서는 웹은 일단 디자인이 신경 쓰이기 때문에 안 좋을지도 모르겠다.( SAP GUI 에서는 디자인따위는 전혀 고려대상이 아니다. ㅋㅋ) http://webdynpro-tutorials.blogspot.kr/p/web-dynpro-abap-tutorials-for-beginners.html http://scn.sap.com/community/web-dynpro-abap - 끗 -

SAP/WD4A & BSP 2014.04.23

Collect 의 사용

Collect 는 Internal Table 에 동일한 필드에 동일한 데이터가 있고, 숫자 또는 금액 필드의 값을 합을 구할 때 유용하게 사용된다. 하지만 collect 의 경우 특정 필드만을 집계 할 수가 없으며 Internal Table 의 데이터가 완전히 동일해야 사용이 가능하다. [예시] Collect 이전 Column1 Column2 AMT1 AMT2 A A 100 200 A A 200 300 A B 400 500 B B 600 700 B C 0 -100 Collect 이후 Column1Column2 AMT1AMT2 AA 300500 AB 400500 BB 600700 BC 0-100 Collect 사용하기전에는 Sort 를 통해서 Collect 할 Column 을 순서로 정렬을 해준 다음 사용..

SAP/ABAP 2014.04.23

ABAP Progress Indicator

ABAP 프로그램은 웹 프로그램들과는 다르게 오랜시간 돌아가는 작업들이 많이 있다. 그러나 화면은 그냥 멈춰 있는것같으니 사용자는 프로그램이 정상적으로 작업이 되고 있는지 알 길이 없다. 그래서 프로그래스 바를 추가 하면 사용자들에게 프로그램이 실행되고 있으며, 또한 얼마나 남았는지를 표시할 수 있다. 하지만 아래 코드를 중간중간 넣어야 하고 루프당 카운터도 계산해서 넣어야 하는 수고로움이 있다. ( 귀찮다. ) Percentage 는 0~100 까지 넣을 수 있다. *&---------------------------------------------------------------------* *& MACRO *&--------------------------------------------------..

SAP/ABAP 2014.04.15

레코드 생성,수정 사용자 Standard Field

CBO 테이블을 만들때 생성,수정정보 를 입력해야 하는 필드를 만들때가 있다. 매번 만들면서도 이름 짓기도 귀찮고 왠지 통일성도 없어보여 보여서 좀 없어보였다. 각각 필요에 따라 만들어도 되지만 Standard domain 중에 필드 텍스트 도 깔끔한 domain 이 있어 기록으로 남긴다. ERDAT ERDAT DATS 8 0 레코드 생성일 ERZET ERZET TIMS 6 0 입력 시간 ERNAM ERNAM CHAR 12 0 오브젝트 생성자 이름 AEDAT AEDAT DATS 8 0 변경일 AEZET AEZET TIMS 6 0 최종변경시간 AENAM AENAM CHAR 12 0 오브젝트 변경자 이름 - 끗 -

SAP/ABAP 2014.04.14

동적 인터널 테이블을 만들때 deep structure 로 생성하기

개발을 하다 보면 동적으로 Internal Table 을 만들어야 할 때가 있다. 경우에 따라 컬럼의 갯수가 변경되는데 동적으로 테이블을 만들다보면 Deep Structure, 즉 Internal Table 에 Internal Table 이 들어가야 하는 경우가 생긴다. 예를 들면 ALV 에서 각 셀별로 색상을 지정해 줄 수 있는데, 안에 Internal Table 로 셀을 지정해야 하는 경우이다. ( 이 경우를 처리하기 위해 찾아보게 되었다. ) 참조 URL : dynamic internal table with deep structure 먼저 전역 Structure 를 생성한다. (SE11 을 이용하여 ZZEXTEND_FIEDCAT 을 생성) * 전역변수 선언 시작 DATA : gt_fieldcatal..

SAP/ABAP 2014.04.11
반응형