KR101062258B1 - Development method of enterprise resource management work program using real time event pattern processor - Google Patents

Development method of enterprise resource management work program using real time event pattern processor Download PDF

Info

Publication number
KR101062258B1
KR101062258B1 KR1020090000687A KR20090000687A KR101062258B1 KR 101062258 B1 KR101062258 B1 KR 101062258B1 KR 1020090000687 A KR1020090000687 A KR 1020090000687A KR 20090000687 A KR20090000687 A KR 20090000687A KR 101062258 B1 KR101062258 B1 KR 101062258B1
Authority
KR
South Korea
Prior art keywords
screen
business
resource management
program
function
Prior art date
Application number
KR1020090000687A
Other languages
Korean (ko)
Other versions
KR20100081449A (en
Inventor
권영범
강신재
Original Assignee
권영범
주식회사 영림원소프트랩
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by 권영범, 주식회사 영림원소프트랩 filed Critical 권영범
Priority to KR1020090000687A priority Critical patent/KR101062258B1/en
Publication of KR20100081449A publication Critical patent/KR20100081449A/en
Application granted granted Critical
Publication of KR101062258B1 publication Critical patent/KR101062258B1/en

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/40Information retrieval; Database structures therefor; File system structures therefor of multimedia data, e.g. slideshows comprising image and additional audio data
    • G06F16/43Querying
    • G06F16/432Query formulation
    • G06F16/434Query formulation using image data, e.g. images, photos, pictures taken by a user
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F30/00Computer-aided design [CAD]
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F30/00Computer-aided design [CAD]
    • G06F30/10Geometric CAD
    • G06F30/18Network design, e.g. design based on topological or interconnect aspects of utility systems, piping, heating ventilation air conditioning [HVAC] or cabling

Landscapes

  • Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • Theoretical Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Geometry (AREA)
  • General Engineering & Computer Science (AREA)
  • Evolutionary Computation (AREA)
  • Computer Hardware Design (AREA)
  • Data Mining & Analysis (AREA)
  • Databases & Information Systems (AREA)
  • Multimedia (AREA)
  • Mathematical Physics (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Computational Mathematics (AREA)
  • Mathematical Analysis (AREA)
  • Mathematical Optimization (AREA)
  • Pure & Applied Mathematics (AREA)
  • Stored Programmes (AREA)

Abstract

본 발명은 실시간 이벤트 패턴 처리기를 이용한 전사적 자원 관리 업무 프로그램 개발 방법에 관한 것이다.The present invention relates to a method for developing a company-wide resource management work program using a real-time event pattern processor.

업무 프로그램의 비즈니스 로직을 기능단위로 블록 정의하여 다수의 기능 블록을 독립적인 모듈로 프로그래밍 된다. 업무 프로그램의 기능 블록들이 시스템 내에 다수 존재한다. 또한, 이러한 기능 블록이 화면상에서도 블록화로 구성되도록 프로그래밍 된다. 즉 화면을 처리 단위별로 블록화 한 후에, 개발자가 코딩을 하는 대신에 기능 블록의 서비스와 화면의 처리 단위를 패턴화된 처리 등록기를 통해서 세팅함으로써 업무모듈을 창출할 수 있다. By defining the business logic of a business program as a functional unit, many functional blocks are programmed as independent modules. There are many functional blocks of a business program in the system. In addition, these functional blocks are programmed to be organized in blocks on the screen. That is, after blocking screens by processing units, a developer can create a business module by setting a service of a function block and processing units of a screen through a patterned process register instead of coding.

Description

실시간 이벤트 패턴 처리기를 이용한 전사적 자원 관리 업무 프로그램 개발 방법{METHOD FOR DEVELOPING BUSINESS PROGRAM USING REAL TIME EVENT PATTERN PROCESSING PROGRAM IN ENTERPRISE RESOURCE PLANNING SYSTEM}METHODS FOR DEVELOPING BUSINESS PROGRAM USING REAL TIME EVENT PATTERN PROCESSING PROGRAM IN ENTERPRISE RESOURCE PLANNING SYSTEM}

본 발명은 전사적 자원 관리(Enterprise Resource Planning; ERP)에 관한 것이며, 특히 ERP 구성을 위한 업무 프로그램 개발 방법론에 관한 것이다.The present invention relates to enterprise resource planning (ERP), and more particularly to a methodology for developing work programs for ERP configuration.

기업활동을 위해 쓰이는 기업 내의 모든 인적, 물적 자원을 효율적으로 관리하여 궁극적으로 기업의 경쟁력을 강화시키기 위한 통합정보 시스템 기술로서의 ERP는 현재 각 기업체의 통합 솔루션으로서 각광을 받고 있다.ERP as an integrated information system technology for efficiently managing all human and physical resources in a company used for corporate activities and ultimately strengthening the company's competitiveness is currently in the spotlight as an integrated solution for each enterprise.

ERP 시스템은 기업의 경영활동을 위해 다수의 시스템, 즉, 생산과 자재, 구매와 수입, 영업과 물류, 운영관리, 회계, 인사, 급여 등의 운영 시스템을 하나의 체계로 통합적인 시스템으로 재구축함으로써 생산성을 극대화하는 소프트웨어 패키지이다. 이러한 ERP 시스템은, "계획(Plan) → 업무 진행(Do) → 성과측정(See)"의 경영 과정이 다양한 업무를 포괄하면서 유기적으로 연결되어야 하며, 또한 끊임없 이 변화하는 비즈니스에 신속하고 유연하게 대처할 수 있어야 한다. 이러한 사항들은 ERP 시스템의 프로그래밍 개발 단계에서부터 적극적으로 고려될 필요가 있다. 즉, 다양한 업무의 유기적인 연결과 변화에 대한 신속하고 유연한 대처가 가능한 시스템 환경이 구축되어야 하며, 이는 또한 사용자 단말의 화면을 통해 구조화되어야 한다.The ERP system reconstructs a number of systems, including production and materials, purchasing and imports, sales and logistics, operations management, accounting, human resources, and salary, into an integrated system for corporate management. It is a software package that maximizes productivity. This ERP system requires that the management process of "Plan → Do → See" encompasses various tasks and is organically connected. You must be able to cope. These issues need to be actively considered from the programming development stage of the ERP system. That is, a system environment capable of quick and flexible response to organic connection and change of various tasks should be constructed, which should also be structured through the screen of the user terminal.

ERP 시스템의 업무 프로그램은 수요자의 요구사항에 따라 업무 모듈들이 달라지며, 또한 요구사항의 변화로 말미암아 화면에 대한 수정이나 Customizing이 빈번하게 요구된다. 한편, ERP 시스템에서 각 화면들에 요구되는 프로그래밍적인 기능들은 공통되는 부분이 많고 비슷한 기능들이 많이 구현되는 특징이 있다. The work program of the ERP system has different business modules according to the requirements of the consumer, and the modification or customizing of the screen is frequently required due to the change of requirements. On the other hand, in the ERP system, the programming functions required for each screen have many features in common and many similar functions are implemented.

그런데 기존의 프로그래밍 방식은 코드로 화면을 제작한 후에 빌드라는 과정을 거쳐야 하는 번거로움이 있었다. 또한 기능을 파악하거나 어떤 서비스가 연결되어 있는지를 확인하기 위해서는 소스 코드를 일일이 분석해야만 했다. 기업의 여러 가지 업무가 상호 유기적인 관계를 갖고 상호 유사한 업무 특성을 갖기 때문에, ERP 업무 프로그램도 다른 업무 영역에서조차 공통된 기능이 구현될 가능성이 매우 높다. 따라서 해당 공통 기능을 재사용할 수 있다면, 업무 프로그램의 개발, 관리 및 활용의 면에서 큰 장점을 갖게 될 것이다. 그러나 종래의 프로그래밍 방식은 그 기능을 추려내기도 어려울 뿐만 아니라 디버그 또한 쉽지 않았다.By the way, the existing programming method has a hassle that has to go through the process of building the screen after the code. In addition, the source code had to be analyzed manually to understand the features or to determine which services were connected. Because the various tasks of an enterprise are organic and have similar business characteristics, ERP business programs are very likely to implement common functions even in other business areas. Thus, if the common functionality can be reused, it will have a great advantage in terms of developing, managing and utilizing business programs. However, conventional programming is difficult to pinpoint and not easy to debug.

ERP 시스템 구축에 투입되는 개발자의 관점에서 보자면, 프로그래밍 언어에 대한 높은 이해와 상당한 교육기간이 필요하다. 종래의 방식에서는 개발자들의 프로그래밍 스킬에 따라 제작되는 화면의 퀄리티(Quality)가 크게 영향을 받게 되는 데, 퀄리티를 일정 수준이상 유지하기 위해서는 개발자들에게 과부하가 따르게 마련이다. 더욱이 프로그래밍된 종래의 업무에 사소한 변화가 가해지거나 수정 요청이 발생되는 경우, 개발자인 그 또는 그녀는 새롭게 일일이 프로그래밍하여야 하기 때문에 그와 같은 과부하는 더욱 증폭되는 면이 있었다. 결과적으로 사소한 요구 조건 변화에 따라 비슷한 화면을 다량으로 중복 생산해 내어 개발자 부하가 증가되는 문제점이 있었던 것이다.From a developer's point of view in building an ERP system, a high understanding of the programming language and a significant training period are required. In the conventional method, the quality of the screen produced according to the programming skills of the developers is greatly affected. To maintain the quality above a certain level, the developers are overloaded. Moreover, if a minor change is made to a conventional work that is programmed or a modification request is made, such overload is further amplified because he or she, a developer, needs to program anew. As a result, there was a problem that the developer load was increased by repeatedly producing a large number of similar screens in accordance with a slight change in requirements.

ERP 시스템의 수요자인 기업의 관리자 입장에서도, 빈번하고 다양한 요구변화가 있을 때마다 개발자에게 프로그램 수정을 요청하고 기다려야 하기 때문에, 그러한 요구변화에 신속하고 유연하게 대처할 수 없는 문제점도 있었다. The manager of a company, a consumer of an ERP system, also had to make a request for program modification to the developer whenever there were frequent and various demand changes, and thus, there was a problem in that it could not cope with such a change quickly and flexibly.

도 1은 종래의 시스템에 있어서, 업무 프로그램 개발 방법에 관한 개발자와 사용자와의 관계의 개략적인 개념을 도시하고 있다. 도 1에 도시 되어 있는 바와 같이, 업무 프로그램에는 다수의 업무 모듈(4)들이 포함되어 있고, 종래에는 이것들이 각각 별도로 개발되었다. 또한 각각의 업무모듈은 각각의 기능이나 고정들이 소스 코드 내부에 종속되어 있기 때문에, 사용자 화면단에서는 능동적으로 변경할 수가 없었다. 사용자(2)가 새로운 기능을 추가하거나 또는 수정을 하고자 하는 경우에는, 개발자(2)에게 요청해야 하고, 개발자(2)가 각각 별도로 코딩 및 빌드(3) 절차를 거쳐서 새로운 기능이 추가되거나 수정된 업무 모듈을 개발하여야 했다. 그러다 보니, 개발자의 프로그래밍 작업에 대한 부하가 증가하는 문제점이 있었고, 각각의 업무 모듈에 존재하는 공통 부분에 대한 재사용의 여지가 존재하지 못했던 것이다. 더욱이 비즈니스 환경 변화에 대하여 기업이 신속하고 유연하며 경제적으 로 대처하는데 있어서, 프로그램적인 벽이 존재하였다.1 illustrates a schematic concept of a relationship between a developer and a user in a method of developing a work program in a conventional system. As shown in Fig. 1, the work program includes a plurality of work modules 4, and these are conventionally developed separately. In addition, each work module could not be actively changed in the user screen because each function or fixed depends on the source code. If the user 2 wants to add or modify a new function, he or she should request the developer 2, and the developer 2 has separately added or modified a new coding and build process. The task module had to be developed. As a result, there was a problem that the load on the developer's programming work was increased, and there was no room for reuse of common parts existing in each work module. Moreover, there has been a programmatic barrier for companies to respond quickly, flexibly and economically to changes in the business environment.

본 발명의 발명가는 위와 같은 문제점을 해결하기 위하여 연구 노력한 결과, 본 발명을 완성하였다. The inventor of the present invention has completed the present invention as a result of research efforts to solve the above problems.

위와 같은 종래기술의 문제점을 해결하기 위하여, 본 발명의 목적은 다음 각 사항으로 정리될 수 있다.In order to solve the problems of the prior art as described above, the object of the present invention can be summarized as follows.

(1) 업무 프로그램 개발 생산성을 높이기 위해서 보다 신속하고 용이하게 개발할 수 있는 수단을 제공하고자 한다.(1) Development of work program We intend to provide means to develop more quickly and easily in order to increase productivity.

(2) 기업의 다양한 업무 중에는 공통되는 요소가 많기 때문에, 프로그램 개발시에 이러한 공통 요소를 재사용할 수 있는 시스템 구축이 필요하다.(2) Since there are many common elements among various business tasks, it is necessary to build a system that can reuse these common elements in program development.

(3) 또한, 상기 공통 요소는 결과적으로 사용자 단말의 화면에 구현되는 것이기 때문에, 업무의 주체가 되는 기업의 입장에서, 기업의 관리자 또는 그 관리자와 최밀접한 컨설턴트나 기획자 선에서 화면을 이용하여 스스로 프로그램을 변경할 수 있는 수단을 제공하고자 한다.(3) In addition, since the common element is ultimately implemented on the screen of the user terminal, the screen of the company that is the subject of the work is to use the screen by the consultant or the planner who is closest to the manager of the company or the manager. We want to provide a means to change the program.

(4) 개발자의 관점에서는, 개발부하를 저감하고, 개발생산성과 재사용성을 획기적으로 고양시킴으로써, 시스템 구축에 소요되는 프로젝트 기간과 비용을 절감할 수 있는 방법을 제공하고자 한다. (4) From the developer's point of view, we will provide a way to reduce the project load and the time required to build the system by reducing development load and dramatically increasing development productivity and reusability.

한편, 본 발명의 명시되지 않은 또 다른 목적들은 하기의 상세한 설명 및 그 효과로부터 용이하게 추론할 수 있는 범위 내에서 추가적으로 고려될 것이다.On the other hand, other unspecified objects of the present invention will be further considered within the range that can be easily inferred from the following detailed description and effects.

위와 같은 목적을 달성하기 위하여, 본 발명은, 전사적 자원 관리 시스템의 전사적 자원 관리 업무 프로그램 개발 방법으로서:In order to achieve the above object, the present invention, as a method of developing an enterprise resource management work program of the enterprise resource management system:

업무 프로그램의 복수의 비즈니스 로직을 각각 기능단위로 블록 정의하여 1개 이상의 기능 블록으로 프로그래밍하는 단계;Programming a plurality of business logics of a business program into one or more functional blocks by defining blocks in functional units, respectively;

단말의 화면을 처리 단위 별로 블록화하는 단계;Blocking the screen of the terminal for each processing unit;

상기 블록화된 기능인 기능 블록과 상기 블록화된 화면의 연결에 대한 패턴을 정의하고 형성하는 단계;Defining and forming a pattern for the connection of the blocked function block and the blocked screen;

상기 패턴에 따라 기능 블록을 선택하고 정의하여 업무 화면을 생성하는 단계; 및Selecting and defining a function block according to the pattern to generate a work screen; And

상기 시스템이 생성된 업무 화면에 다라 순차적으로 기능블록을 실행하는 단계를 포함하는 것을 특징으로 한다.And sequentially executing the function blocks according to the generated business screen.

또한, 바람직하게는, 상기 기능 블록은, 데이터 블록과 메소드를 갖는 것이 좋다.Also, preferably, the functional block has a data block and a method.

또한, 본 발명의 단말 화면은, 3가지 구획으로 분할하고,In addition, the terminal screen of the present invention is divided into three sections,

제1 구획은 기능이 구현될 수 있는 요소들을 배치하되, 이벤트 표시를 하고,The first compartment lays out the elements on which the function can be implemented, but provides an event indication,

제2 구획은 상기 제1구획에서 선택된 요소들에 대한 연결 가능한 이벤트들을 리스트업 하고,The second compartment lists connectable events for the elements selected in the first compartment,

제3 구획은 패턴화된 입력 화면을 통해 실제 이벤트를 등록하는 것으로 블록화하는 것이 바람직하다.Preferably, the third partition is blocked by registering the actual event through the patterned input screen.

또한, 상기 제3 구획은 기능 블록의 메소드를 등록하는 화면 영역이기도 하며, 처리순서, 처리유형, 대상, 선택유형을 메소드 항목으로서 포함하는 것이 바람 직하다.The third partition is also a screen area for registering a method of a functional block, and preferably includes a processing order, processing type, object, and selection type as a method item.

또한, 상기 대상 항목은, 생성하고자 하는 업무 화면 내의 화면 블록들이 리스트 업되는 것이 바람직하다.In addition, it is preferable that screen blocks in a work screen to be created are listed up as the target item.

또한, 본 발명의 다른 국면으로서, 위와 같은 업무 프로그램 개발 방법이 수록되어 있는 컴퓨터 판독 가능한 기록매체를 특징으로 한다.In another aspect of the present invention, there is provided a computer-readable recording medium in which the above method of developing a business program is recorded.

본 발명에 따르면, 개발생산성과 재사용성이 향상되고, 개발자들의 부하가 줄어듦으로써 프로젝트 기간을 단축하여 프로젝트 비용을 줄일 수 있다는 효과를 거둘 수 있다.According to the present invention, development productivity and reusability are improved, and the load of developers is reduced, thereby reducing the project cost by shortening the project period.

또한, 개발자가 아니어도, 컨설턴트나 기획자 선에서 실시간으로 프로그램을 수정, 개발할 수 있다는 장점이 있다. 이러한 장점은 고객과 근접하여 요구사항을 바로 반영해 줄 수 있게 됨으로써 수요자의 다양하고 빈번한 요구변화에 능동적으로 대응할 수 있는 효과를 발휘한다.In addition, even if you are not a developer, there is an advantage in that the program can be modified and developed in real time by a consultant or a planner. This advantage is able to reflect the requirements immediately in close proximity to the customer, thereby effectively responding to the various frequent changes of the consumer's demand.

덧붙여, 런타임 디버그 기능으로 문제 발생시 소스코드를 보지 않아도 모니터링과 오류 원인 파악을 쉽게 할 수 있다는 장점도 있음을 첨언한다.In addition, the runtime debug feature also makes it easy to monitor and identify the cause of an error without having to look at the source code when a problem occurs.

또한, 본 발명의 명세서에서 구체적으로 언급되지 않은 효과라 하더라도, 본 발명의 기술적 특징에 의해 기대되는 잠정적인 효과는 본 발명의 명세서에 기재된 것과 같이 취급됨을 첨언한다.In addition, even if the effect is not specifically mentioned in the specification of the present invention, it is added that the interim effects expected by the technical features of the present invention are treated as described in the specification of the present invention.

이하, 첨부된 도면을 참조하여 본 발명의 실시를 위한 구체적인 내용을 설명한다. 그리고 본 발명을 설명함에 있어서, 관련된 공지기능 등 이 분야의 기술자에게 자명한 사항으로서 본 발명의 요지를 불필요하게 흐릴 수 있다고 판단되는 경우에는 그 상세한 설명을 생략한다.Hereinafter, with reference to the accompanying drawings will be described specific details for the practice of the invention. In the following description of the present invention, when it is determined that the subject matter of the present invention may be unnecessarily obscured as matters obvious to those skilled in the art, such as related well-known functions, the detailed description thereof will be omitted.

도 2는 본 발명의 개략적인 개념을 설명하고 있다. 업무 프로그램의 비즈니스 로직을 기능단위로 블록 정의하여 다수의 기능 블록(10)을 개별적이고 독립적인 모듈로 프로그래밍 된다. N은 1보다 큰 정수로 정의되며, 업무 프로그램의 기능 블록(10)들이 시스템 내에 다수 존재한다. 또한, 이러한 기능 블록(10)이 사용자 단말의 화면(30) 상에서도 블록화로 구성되도록 프로그래밍 된다(①번). 즉 화면(30)을 처리 단위별로 블록화 한 후에, 개발자가 코딩을 하는 대신에 기능 블록(10)의 서비스와 화면(30)의 처리 단위를 패턴화된 방법으로 세팅함으로써(③번) 업무모듈(40)을 창출할 수 있다. 예컨대 기능 1, 기능 2, 기능 3으로 업무모듈(40)을 세팅할 수 있다. 그리고 사용자 단말은 이렇게 만들어진 업무 모듈(40)을 이용하여 ERP 업무를 처리하게 된다. 2 illustrates a schematic concept of the present invention. By defining the business logic of a business program in functional units, a plurality of functional blocks 10 are programmed as individual and independent modules. N is defined as an integer greater than 1, and there are many functional blocks 10 of a business program in the system. In addition, such a function block 10 is programmed to be configured as a block on the screen 30 of the user terminal (No. ①). That is, after blocking the screen 30 for each processing unit, instead of coding the developer, the service module of the function block 10 and the processing unit of the screen 30 are set in a patterned manner (No. 40) can be created. For example, the work module 40 may be set as the function 1, the function 2, and the function 3. In addition, the user terminal processes the ERP task using the task module 40 thus made.

이와 같이, 개발 단계에서 기능별로 일일이 코딩할 필요가 없기 때문에 개발 작업이 매우 용이해졌고, 그에 따른 부수적인 효과로서 사용자 단말의 업무 프로그램 접근성도 매우 높아질 수 있다. 다른 실시예에서는 사용자 단말(20)이 서비스를 새롭게 구성(기능을 추가하거나 수정하는 등)을 하기 위하여 기능들을 선택하는 명 령을 입력할 수도 있다(②번). 이와 같은 명령 처리가 완료되면, 시스템은 자동으로 미리 설정된 규칙에 따라서 선택된 기능 블록(예컨대, 기능 1, 기능 2, 기능 3)들을 연결하여 업무 모듈(40)을 창출할 수 있다.As such, the development work is very easy because there is no need to code for each function at the development stage, and as a side effect, the accessibility of the work program of the user terminal may be very high. In another embodiment, the user terminal 20 may input a command for selecting functions in order to newly configure a service (add or modify a function, etc.) (No. ②). When such command processing is completed, the system may automatically connect the selected function blocks (eg, function 1, function 2, function 3) according to a preset rule to create a business module 40.

도 3은 도 2의 개략적인 개념에 기초하여, 본 발명의 실시간 이벤트 패턴 처리기에 의한 프로그래밍 방법에 의해 시스템 내부에서의 기능블록의 개발과 화면 단에서의 세팅되는 새로운 업무 모듈의 실행까지의 개략적인 전체 프로세스를 나타낸다.FIG. 3 is a schematic diagram of the development of functional blocks in a system and execution of a new work module set at a screen stage by a programming method by the real-time event pattern processor of the present invention, based on the schematic concept of FIG. 2. Represent the entire process.

먼저 업무 시스템 내의 각각의 기능을 블록화하여 프로그래밍한다(S100). 다수의 업무 기능들은 비즈니스 서비스 레이어(Business Service Layer)에서 데이터 블록(Data Block)과 메소드(Method)로 갖는 블록 단위의 서비스로 블록화한다. 그리고 이는 웹 서비스 레이어(Web Service Layer)를 통해 사용자 화면단의 프리젠테이션 레이어(Presentational Layer)와 연결되며, 데이터베이스에 저장되어 있는 데이터를 핸들링할 수 있는 구조를 갖는다. First, each function in the work system is blocked and programmed (S100). Many business functions block to block-based services that have data blocks and methods in the business service layer. It is connected to the presentation layer of the user screen through the web service layer, and has a structure capable of handling data stored in the database.

다음으로 화면의 각 부분을 블록화한다(S200). 이를 통해 시스템의 단말(개발자 단말 또는 사용자 단말)은 각각의 기능들에 대한 소스 분석을 할 필요 없이 화면에 표시되는 기능들을 파악하고, 기능들을 새롭게 정의할 수 있게 된다. 이를 위하여 블록 단위로 구성된 기능들과 화면 연결에 대한 패턴을 형성한다(S300). 기업의 업무 프로그램을 구성하는 각각의 업무들은 공통된 요소를 갖게 되며, 그러한 공통된 요소를 패턴화 하는 것이다.Next, each part of the screen is blocked (S200). Through this, the terminal (developer terminal or user terminal) of the system can grasp the functions displayed on the screen without having to analyze the source of each function, and newly define the functions. To this end, a function and a pattern for screen connection are formed in block units (S300). Each of the tasks that make up a company's work program will have a common element, and will pattern that common element.

다음으로 정의된 상기 패턴에 따라 기능을 정의한다(S400). 단말은 화면상에 가시화된 패턴에 따라 소망하는 기능 요소를 입력수단에 의해 선택 입력하게 되고, 이로써 직접적으로는 새로운 업무 화면을 개발하게 되며, 또한 새로운 업무 모듈을 창출할 수 있게 된다. 이때 입력되는 메소드 정의 내용을, 시스템이 실제 화면 실행시에 독출하여 순차적으로 기능을 실행한다(S500).Next, the function is defined according to the pattern defined (S400). The terminal selects and inputs a desired functional element by an input means according to a pattern visualized on the screen, thereby directly developing a new work screen and also creating a new work module. At this time, the system reads the input method definition contents when the actual screen is executed and sequentially executes the functions (S500).

상기 S300 단계 내지 S500 단계의 구체적인 실시예에 대해서 도 4의 화면구성은 이를 예시하고 있으며, 이에 기초하여 설명한다.The screen configuration of FIG. 4 exemplifies the specific embodiments of steps S300 to S500 and will be described based on this.

도 4에서 도시되어 있는 바와 같이, 화면은 3가지 구획으로 분할될 수 있다. 먼저 화면 내 기능이 구현될 수 있는 모든 요소를 왼쪽에 트리(tree) 형태로 배치할 수 있다. 이때 기능이 붙어 있는 요소는 이벤트 표시를 한다. 우측 시트 부분에는 기능에 대한 정의를 할 수 있는 인터페이스 부분이다. 여기에 입력되는 값은 메소드 개념으로 묶이게 된다. 또한 중간에 위치하는 시트는 이벤트에 기능 메소드를 연결하는 시트로 구성할 수 있다. 실제 화면 실행시에 상기 메소드 정의 내용을 독출하여 순차적으로 기능을 동작시키게 된다(PgmMethod.dll).As shown in FIG. 4, the screen may be divided into three sections. First, all the elements that can be implemented in the screen can be arranged in a tree form on the left side. At this time, the element with the function displays the event. The right side sheet is the interface part that can define the function. The value entered here is bound to the method concept. In addition, the middle sheet can be configured as a sheet that connects a function method to an event. When the actual screen is executed, the method definition is read and the functions are sequentially executed (PgmMethod.dll).

상기 메소드 정의 부분, 즉 우측 시트에 입력되는 부분은, 다음과 같은 항목들이 정의될 수 있다.The following items may be defined in the method definition part, that is, the part input to the right sheet.

- 처리순서 : 기능이 발생하는 순서-Order of processing: Order in which functions occur

- 실행여부 : 해당 Row의 기능을 실행할지 안 할지를 지정-Execution Status: Specify whether or not to execute the function of the relevant row.

- 처리유형 : 화면에 필요한 기능들을 패턴화한 처리 유형 값들Processing Type: Processing type values that pattern the functions required on the screen.

- 대상 : 선택된 처리유형이 처리될 수 있는 대상(컨트롤, 블록, DataSet, 서비스 등)-Target: Target (Control, Block, DataSet, Service, etc.) that the selected processing type can be processed.

- 선택유형 : 대상이 시트처럼 여러 item을 포함하는 경우 선택 범위 지정-Selection type: Specify the selection range when the target contains multiple items like sheets

- Service, Method : 비즈니스 로직으로 정의된 서비스를 연결할 수 있음-Service, Method: Can connect service defined by business logic

- Script : 기존 서비스로 처리가 안 되는 부분을 LuaScript로 보충 구현-Script: Implement LuaScript to supplement the part that cannot be processed by existing service

- 그 외 내부 처리에 필요한 값이 정의될 수 있다. -Other values necessary for internal processing can be defined.

도 4의 화면예에서는 상기에서 언급한 바와 같이 3가지의 독립된 화면 구획이 있고, 이 중 좌측의 2개의 구획된 영역에는 이벤트에 대한 정보를 패턴화한다. 맨 좌측의 영역에는 화면 내에서 이벤트가 연결될 수 있는 요소들을 리스트업 한다. 다음 영역에는, 그 좌측 영역에서 해당 요소가 선택되었을 때의 연결가능한 이벤트들을 리스트업한다. 이 두번째 영역의 이벤트 유형에는 Click, Change, DblClick, LostFocus, MouseDownLeft, MouseDownRight, MouseLeave, KeyDown, DragDrop, LeveCell, ButtonClick, ComboSelChange, CodeHelpBefore, CodeHelpAfter, Changed, FormLoad, FormUnLoad가 리스트업 되었다. In the screen example of FIG. 4, as mentioned above, there are three independent screen sections, and two partitioned areas on the left are patterned with information on an event. The leftmost area lists elements to which events can be connected in the screen. The next area lists up the connectable events when that element is selected in the left area. The event types in this second section are List, Click, Change, DblClick, LostFocus, MouseDownLeft, MouseDownRight, MouseLeave, KeyDown, DragDrop, LeveCell, ButtonClick, ComboSelChange, CodeHelpBefore, CodeHelpAfter, Changed, FormLoad, and FormUnLoad.

여기에서 이벤트(Event)란, 프로그램이 반응하도록 사용자 단말이 생성시키는 동작 또는 일(사건)의 발생을 의미하며, 예컨대 키보의 키를 눌러서 입력한다거나, 마우스 버튼을 클릭하는 것, 마우스를 이동하는 것 등이 있다. 즉, 화면상에서 사용자 단말이 어떤 액션을 취하여 기능하도록 하는 것으로 이해될 수 있다.Here, an event refers to an action or occurrence of an event generated by a user terminal so that a program reacts. For example, input by pressing a key of a keyboard, clicking a mouse button, or moving a mouse. Etc. That is, it can be understood that the user terminal takes a certain action on the screen to function.

이를 시나리오 예를 들어 설명하자면, 예컨대 영업모듈에서 담당자별 영업실 적을 조회, 저장하는 화면이 있다고 가정하면, 이 기능을 구현하기 위한 절차는, 'Input 조건' --> service 처리(영업실적 데이터 조회) --> output 사용자 단말의 화면에 표시의 순서로 진행한다. 보통의 조회의 경우, 중간에 위치한 서비스의 종류나, input으로 들어가는 조건, output으로 나오는 데이터의 내용은 다르지만, 그 절차나 그 기능을 구현하기 위한 프로세스는 거의 비슷하다고 볼 수 있다. 다음과 같다. To illustrate this scenario, for example, assuming that there is a screen for inquiring and storing sales performance by person in charge in the sales module, the procedure for implementing this function is 'Input condition'-> service processing (inquiry of sales performance data). )-> output Proceed with the order of display on the screen of the user terminal. In the case of normal inquiry, the kind of service located in the middle, the conditions of entering the input, the contents of the data coming out of the output are different, but the procedure and the process for implementing the function are almost similar. As follows.

1. 화면 내 블록 중에, 조회조건으로 넘겨질 블록을 선택하여 내부적으로 자동 데이터 수집;1. Automatically collect data internally by selecting a block to be passed as an inquiry condition among blocks in the screen;

2. 적합한 서비스 연결;2. suitable service connection;

3. 데이터를 받아서, 화면 블록 중에, 데이터가 뿌려 져야할 알맞은 블록에 자동으로 데이터 출력; 3. Receives data, automatically outputs the data to the appropriate block to be scattered, among the screen blocks;

본 발명의 실시간 이벤트 패턴 처리기는 상기와 같은 일련의 과정을 등록할 수 있도록, 화면을 구성하고 있다. 또한, 화면 내의 버튼 클릭, 데이터 변경 등의 이벤트(event)가 발생했을 때 후처리에 대한 내용도 이러한 방법으로, 세팅을 통해 기능을 구현할 수 있다. The real-time event pattern processor of the present invention configures a screen to register the above-described series of processes. In addition, the post-processing when an event such as a button click on the screen or a data change occurs in this way can be implemented through a setting.

한편, 다시 도 4의 화면구성예로 돌아와서, 우측 영역은 패턴화된 입력화면을 통해 실제 이벤트를 등록하는 영역이다. 여기에서 패턴이라 함은 미리 정의된 처리 패턴을 의미하며, 본 발명의 이벤트 패턴 처리기는 그러한 패턴을 조합해서 그 일련의 처리과정을 생성하는 프로그램으로 이해될 수 있다. 우측 영역의 시트 상에 '처리유형'(100)은 특정한 비즈니스 업무에서 정형화될 수 있는 처리 유형들, 예컨대, 데이터 수집, 화면출력, DataSet조작, 처리결과 반영, 서비스 호출, Checking, 호출할 스크립트, 스크립트 CodeHelp 등이 포함될 수 있다. 다음으로 '대상' 필드(200)에는 해당 업무 화면(이벤트 패턴 처리기를 통해 만들고자 하는 화면) 내의 화면 블록 들이 리스트업된다. 즉, 처리유형 필드에서 선택한 처리내용을 화면 내의 어떤 블록을 대상으로 할 것인가를 지정하는 것이다.Meanwhile, returning to the screen configuration example of FIG. 4 again, the right area is an area for registering the actual event through the patterned input screen. Here, the pattern means a predefined processing pattern, and the event pattern processor of the present invention may be understood as a program that combines such patterns to generate a series of processing. On the sheet in the right area, the 'process type' 100 is the type of processing that can be formalized in a particular business task, such as data collection, display, DataSet operation, processing result reflection, service call, checking, script to call, Scripts such as CodeHelp. Next, screen blocks in the corresponding work screen (the screen to be created through the event pattern processor) are listed in the 'target' field 200. That is, it is to designate which block in the screen the processing contents selected in the processing type field are to be targeted.

또한, '선택 유형' 필드(300)에 있어서, 화면 내에는 master성 데이터(화면에서 한 개만 존재하는 데이터유형)가 있는가 하면, detail성 데이터(시트나 트리처럼 동일한 유형이 그 내용만 달리하여 반복적으로 보여지는 유형)이 있다. 이러한 detail성 데이터를 표현할 때는.선택유형 필드의 콤보박스에 보여지듯이 여러가지 유형이 선택될 수 있다.In addition, in the 'selection type' field 300, there is master property data (a data type having only one on the screen) in the screen, and detail data (the same type as a sheet or a tree is repeated with different contents only). Type shown). When representing such detail data, several types can be selected, as shown in the combo box of the Selection Type field.

만일, 상기 처리유형(100)에서 서비스 호출을 선택하였다면, 서비스 필드와 메소드 필드에서 적합한 서비스를 선택하여, 내부적으로 이 서비스를 호출하여 실행될 수 있도록 구성한다. 실제 예를 들어서, '조회' 기능을 구현하고자 한다면, 시트의 각 행은 도 5와 같이 입력하면 조회 기능이 구현될 수 있다.If the service call is selected in the processing type 100, an appropriate service is selected in the service field and the method field, and configured to be called and executed internally. For example, if a user wants to implement a 'lookup' function, each row of the sheet may be entered as shown in FIG. 5 to implement a search function.

본 발명의 위와 같은 구성 상의 특징을 다시 한 번 입체적으로 이해하고자 한다면, 다시 종래의 업무 프로그래밍 방식과 비교해 보는 것도 유익한 일이다. 즉, 종래의 프로그래밍 방식은 업무화면에 어떤 기능을 구현하기 위해 코딩을 할 때, 이런 저런 작업들은 모든 개발자들이 개별적으로 코딩작업과 빌드 등을 했던 것인데, 본 발명은 그러한 코딩 작업들이 동일한 또는 유사한 기능을 반복적으로 코딩해 왔다는 사실에서 출발하여, 반복적으로 진행해 온 코딩 작업들을 구분하고, 이를 패턴화 함으로써 일일이 코딩하지 않더라도 단지 세팅을 통해서 업무 화면을 만들 수 있게 된 것이다.If you want to three-dimensionally understand the above-described configuration features of the present invention, it is also advantageous to compare with the conventional business programming method again. That is, in the conventional programming method, when coding to implement a function on a work screen, all of these tasks are coded and built by all developers individually, and the present invention provides the same or similar functions. Starting from the fact that we have coded repeatedly, we have distinguished the coding tasks that have been repeatedly performed and patterned them so that we can create work screens only through settings even if we do not code them.

한편, 본 발명에서 '실시간'이라는 용어의 의미는, 빌드 등의 과정 없이, 변경 즉시 화면에 반영된다는 의미로 해석될 것임을 첨언한다.Meanwhile, in the present invention, the term 'real time' is to be interpreted to mean that the change is immediately reflected on the screen without a process such as build.

또한, 본 발명의 보호범위가 이상에서 명시적으로 설명한 실시예에 의해 제한되는 것은 아니다. 또한, 본 발명이 속하는 기술분야에서의 자명한 변경이나 치환으로 말미암아 본 발명의 보호범위가 제한될 수도 없음을 첨언한다.In addition, the protection scope of the present invention is not limited by the embodiment explicitly described above. In addition, it should be noted that the protection scope of the present invention may not be limited due to obvious changes or substitutions in the technical field to which the present invention belongs.

도 1은 업무 프로그램 개발 방법에 관한 개발자와 사용자와의 관계의 개략적인 개념을 도시하는 도면이다.1 is a diagram illustrating a schematic concept of a relationship between a developer and a user in a work program development method.

도 2는 본 발명의 업무 프로그램 개발 방법론에 대한 개략적인 개념 구성을 나타내는 도면이다.2 is a schematic conceptual diagram of the business program development methodology of the present invention.

도 3은 본 발명에 따른 전체 프로세스 구성예를 도시한 도면이다.3 is a diagram showing an example of the overall process configuration according to the present invention.

도 4는 본 발명에 따른 화면 구성예이다.4 is a screen configuration example according to the present invention.

도 5는 본 발명에 따라 '조회' 기능을 실제 구현하는 화면의 시트예를 나타내는 도면이다.5 is a diagram illustrating an example of a sheet of a screen that actually implements a 'query' function according to the present invention.

※ 첨부된 도면은 본 발명의 기술사상에 대한 이해를 위하여 참조로서 예시된 것임을 밝히며, 그것에 의해 본 발명의 권리범위가 제한되지는 아니한다.The accompanying drawings show that they are illustrated as a reference for understanding the technical idea of the present invention, by which the scope of the present invention is not limited.

Claims (6)

전사적 자원 관리 시스템의 전사적 자원 관리 업무 프로그램 개발 방법으로서:As a method of developing an enterprise resource management work program of an enterprise resource management system: 업무 프로그램의 복수의 비즈니스 로직을 각각 기능단위로 블록 정의하여 1개 이상의 개별적이고 독립적인 기능 블록으로 구성하는 단계 - 이 단계에서 1개 이상의 기능들은 비즈니스 서비스 레이어에서 데이터 블록과 메소드를 갖는 블록 단위의 서비스로 블록화하며, 웹 서비스 레이어를 통해 사용자 단말의 화면단의 프리젠테이션 레이어와 연결되며, 데이터베이스에 저장되어 있는 데이터를 핸들링할 수 있는 구조로 된다-;Defining a plurality of business logic of a business program in functional units, each of which consists of one or more individual and independent functional blocks.In this stage, one or more of the functions is a block unit having data blocks and methods in the business service layer. Blocked as a service, connected to the presentation layer of the screen stage of the user terminal through the web service layer, and has a structure capable of handling data stored in the database; 상기 기능블록이 사용자 단말의 화면 상에서도 블록화로 구성되도록, 단말의 화면을 처리 단위 별로 블록화하는 단계;Blocking the screen of the terminal for each processing unit so that the functional block is configured to be blocked on the screen of the user terminal; 코딩하는 대신에 상기 블록화된 기능인 기능 블록과 상기 블록화된 화면의 연결에 대한 패턴을 정의하는 단계;Defining a pattern for the concatenation of the blocked block with a functional block instead of coding; 상기 패턴에 따라 기능 블록을 선택하고 정의하여 업무 화면을 생성함으로써 업무 모듈을 세팅하는 단계; 및Setting a work module by selecting and defining a function block according to the pattern to generate a work screen; And 상기 시스템이 생성된 업무 화면에 따라 순차적으로 기능블록을 실행하는 단계를 포함하며, And sequentially executing the function blocks according to the generated business screen. 사용자 단말이 화면상에 가시화된 상기 패턴에 따라 원하는 기능 블록을 입력수단에 의해 선택 입력하는 경우에, 새로운 업무 화면이 세팅되고, 상기 시스템이, 코딩 및 빌드 과정 없이 실시간으로, 실제 화면 실행 시에 입력된 메소드 정의 내용을 독출하여 순차적으로 기능을 실행하도록 한 것을 특징으로 하는, 실시간 이벤트 패턴처리기를 이용한 전사적 자원 관리 업무 프로그램 개발 방법.When the user terminal selects and inputs a desired function block by the input means according to the pattern visualized on the screen, a new work screen is set, and the system is executed in real time, in real time, without coding and building process. A method for developing a company-wide resource management work program using a real-time event pattern processor, characterized in that the function is sequentially executed by reading an input method definition. 삭제delete 제1항에 있어서,The method of claim 1, 상기 단말의 화면은, 3가지 구획으로 분할하고,The screen of the terminal is divided into three sections, 제1 구획은 기능이 구현될 수 있는 요소들을 배치하되, 이벤트 표시를 하고,The first compartment lays out the elements on which the function can be implemented, but provides an event indication, 제2 구획은 상기 제1구획에서 선택된 요소들에 대한 연결 가능한 이벤트들을 리스트업 하고,The second compartment lists connectable events for the elements selected in the first compartment, 제3 구획은 패턴화된 입력 화면을 통해 실제 이벤트를 등록하는 것으로 블록화하는, 실시간 이벤트 패턴 처리기를 이용한 전사적 자원 관리 업무 프로그램 개발 방법.The third block is blocked by registering the actual event through the patterned input screen, enterprise resource management work program development method using a real-time event pattern processor. 제3항에 있어서,The method of claim 3, 상기 제3 구획은 기능 블록의 메소드를 등록하는 화면 영역이기도 하며, The third partition is also a screen area for registering a method of a function block. 처리순서, 처리유형, 대상, 선택유형을 메소드 항목으로서 포함하는 것인, 실시간 이벤트 패턴 처리기를 이용한 전사적 자원 관리 업무 프로그램 개발 방법.A method for developing a company-wide resource management work program using a real-time event pattern processor, comprising a processing sequence, a processing type, a target, and a selection type as method items. 제4항에 있어서,5. The method of claim 4, 상기 대상 항목은, 생성하고자 하는 업무 화면 내의 화면 블록들이 리스트 업되는 것인, 실시간 이벤트 패턴 처리기를 이용한 전사적 자원 관리 업무 프로그램 개발 방법.Wherein the target item, screen blocks in the business screen to be created, list-up, enterprise resource management business program development method using a real-time event pattern processor. 제1항, 제3항 내지 제5항 중 어느 한 항의 실시간 이벤트 패턴처리기를 이용한 전사적 자원 관리 업무 프로그램 개발 방법을 구현한 프로그램이 수록되어 있는 컴퓨터 판독 가능한 기록매체.A computer-readable recording medium containing a program that implements a method for developing a company-wide resource management business program using the real-time event pattern processor of claim 1.
KR1020090000687A 2009-01-06 2009-01-06 Development method of enterprise resource management work program using real time event pattern processor KR101062258B1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
KR1020090000687A KR101062258B1 (en) 2009-01-06 2009-01-06 Development method of enterprise resource management work program using real time event pattern processor

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
KR1020090000687A KR101062258B1 (en) 2009-01-06 2009-01-06 Development method of enterprise resource management work program using real time event pattern processor

Publications (2)

Publication Number Publication Date
KR20100081449A KR20100081449A (en) 2010-07-15
KR101062258B1 true KR101062258B1 (en) 2011-09-05

Family

ID=42641866

Family Applications (1)

Application Number Title Priority Date Filing Date
KR1020090000687A KR101062258B1 (en) 2009-01-06 2009-01-06 Development method of enterprise resource management work program using real time event pattern processor

Country Status (1)

Country Link
KR (1) KR101062258B1 (en)

Families Citing this family (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20130117055A1 (en) * 2011-11-09 2013-05-09 Microsoft Corporation Techniques to provide enterprise resource planning functions from an e-mail client application
KR101530888B1 (en) * 2013-10-08 2015-06-24 국방과학연구소 Method for refactoring software for improving weapon system

Non-Patent Citations (2)

* Cited by examiner, † Cited by third party
Title
분산환경에서 순차 다이어그램을 이용한 협력 개발, 박지현외 2인, 한국경영과학회 학술대회논문집 제9권제2호 pp223-226, 2000.
소프트웨어 재사용 기법을 이용한 현장제어시스템의 구현 방법에 관한 연구, 김종수외 1인, 한국산업경영시스템학회 논문지 Vol.31, No.4, pp168-176, 2008.12

Also Published As

Publication number Publication date
KR20100081449A (en) 2010-07-15

Similar Documents

Publication Publication Date Title
US7164422B1 (en) Parameterized graphs with conditional components
US7089256B2 (en) Universal data editor
US7562340B2 (en) Method for graphically building business rule conditions
WO2021001845A1 (en) System and method for modelling and monitoring processes in organizations using digital twins
CA2971784A1 (en) Healthcare workflow system
US9552194B2 (en) System and method for creating a graphical user interface within a manufacturing execution system
US20160350079A1 (en) Method and system of editing workflow logic and screens with a gui tool
US20130167050A1 (en) Method and system for customizing a graphic user interface of a manufacturing execution system screen
KR20060087998A (en) Unified model for authoring and executing flow-based and constraint-based workflows
AU2019201100B2 (en) Data modelling and flow engine for building automated flows within a cloud based developmental platform
US9513874B2 (en) Enterprise computing platform with support for editing documents via logical views
JP5614843B2 (en) Integrated software design and operation management system
EP2388697B1 (en) System and method for managing conflicts between business functions configurations
US20090307653A1 (en) Representation of software application functionality
Strelich The Software Life Cycle Support Environment (SLCSE): a computer based framework for developing software systems
US10114622B2 (en) Method and system for customizing a graphic user interface of a manufacturing execution system screen
KR101062258B1 (en) Development method of enterprise resource management work program using real time event pattern processor
US11454955B2 (en) Method and system for controlling a manufacturing plant with a manufacturing execution system
US20130167051A1 (en) Method and system for customizing a graphic user interface of a manfuacturing execution system screen
KR101041501B1 (en) Process automation system using business work flow in enterprise resource planning system and method of the same
Peng et al. User-Oriented Measurement of Software Flexibility
US20090070167A1 (en) Rule based product assessment method and apparatus
Schulze et al. Language based simulation models as management tools for assembly lines
Deelstra Evolution of Variability in Software Product Families
CA2639000A1 (en) Method and system of editing workflow logic and screens with a gui tool

Legal Events

Date Code Title Description
A201 Request for examination
E902 Notification of reason for refusal
E701 Decision to grant or registration of patent right
GRNT Written decision to grant
FPAY Annual fee payment

Payment date: 20140702

Year of fee payment: 4

FPAY Annual fee payment

Payment date: 20150623

Year of fee payment: 5

FPAY Annual fee payment

Payment date: 20160621

Year of fee payment: 6

FPAY Annual fee payment

Payment date: 20180711

Year of fee payment: 8

FPAY Annual fee payment

Payment date: 20191104

Year of fee payment: 9

FPAY Annual fee payment

Payment date: 20200311

Year of fee payment: 10