검수요청.png검수요청.png

"엔티티"의 두 판 사이의 차이

위키원
이동: 둘러보기, 검색
잔글
잔글 (같이 보기)
 
(같은 사용자의 중간 판 2개는 보이지 않습니다)
2번째 줄: 2번째 줄:
  
 
엔티티는 사물의 구조나 상태, 동작 등을 모델로 표현하는 경우, 그 모델의 구성요소를 말한다. [[시스템]]이나 [[프로그램]] 등도 하나의 [[모델]]로 생각할 수 있다. 이 모델에서, 예를 들면 정보를 통일적·추상적으로 취급할 때, 이 개별 정보를 엔티티라고 부른다. 컴퓨터 시스템 중에서 데이터, 파일, 원시 프로그램(source program), 목적 프로그램(object program) 등도 각각 하나의 엔티티에 해당한다.
 
엔티티는 사물의 구조나 상태, 동작 등을 모델로 표현하는 경우, 그 모델의 구성요소를 말한다. [[시스템]]이나 [[프로그램]] 등도 하나의 [[모델]]로 생각할 수 있다. 이 모델에서, 예를 들면 정보를 통일적·추상적으로 취급할 때, 이 개별 정보를 엔티티라고 부른다. 컴퓨터 시스템 중에서 데이터, 파일, 원시 프로그램(source program), 목적 프로그램(object program) 등도 각각 하나의 엔티티에 해당한다.
 +
 +
== 개요 ==
 +
엔티티(entity)는 데이터베이스에 표현하려고 하는 유형, 무형의 객체로서 서로 구별되는 것을 뜻한다. 이 개체는 현실 세계에 대해 사람이 생각하는 개념이나 정보의 단위로서 의미를 가지고 있다. 이것은 컴퓨터가 취급하는 파일의 레코드(record)에 대응한다. 이 개체는 그 단독으로 존재할 수 있으며, 정보로서의 역할을 한다. 하나의 개체는 하나 이상의 속성, 즉 [[속성]](attribute)으로 구성되고 각 속성은 그 개체의 특성이나 상태를 기술해 준다. 예를 들어, 학생이라는 개체는 학번, 이름, 학과라는 3개의 속성들로 구성되어 있다. 이 때 학번, 이름, 학과는 학생이라는 개체가 가지고 있는 특성, 즉 값을 나타내고 있는 것이다. 이와 같이 속성, 즉 속성이라고 하는 것은 이름을 가진, 데이터의 가장 작은 논리적 단위가 된다. 보통 파일 구조에서는 데이터 항목(data item) 또는 필드(field)라고도 한다. 정보의 측면에서 볼 때 이 속성은 그 자체만으로는 중요한 의미를 표현하지 못하기 때문에 단독으로 존재하지는 못한다. 앞의 예에서 각 속성들 즉, 학번, 이름, 학과는 개별적으로는 우리에게 어떤 정보를 제공해 주지 못하지만 이것들이 모여 학생이라는 개체를 구성해서 표현할 때는 큰 의미를 제공하고 있다. 물론 각 속성이 갖는 값은 시간에 따라 변할 수도 있다. 일반적으로, 한 속성이 취할 수 있는 모든 값을 총칭해서 도메인(domain)이라 한다.<ref>환, 〈[http://blog.naver.com/PostView.nhn?blogId=jjhstr&logNo=60097939589&proxyReferer=https:%2F%2Fwww.google.com%2F DB에서 entity란?]〉, 2009-12-24</ref>
 +
 +
== 특징 ==
 +
* 반드시 엔티티가 사용되는 곳의 업무에서 필요하며 관리하고자 하는 정보 엔티티가 포함하는 인스턴스에 대해 유일한 식별자로 식별이 가능해야 한다.
 +
* 엔티티는 지속적으로 존재하는 두개 이상의 인스턴스들의 조합이어야 한다.
 +
* 엔티티는 반드시 속성을 지녀야 한다.
 +
* 엔티티는 업무 프로세스에 의해서 이용되어야 한다.
 +
* 엔티티는 다른 엔티티와 최소 한 개 이상의 관계가 있어야 한다.<ref name='entity_info2'>Tigercow, 〈[https://doorbw.tistory.com/227 엔터티(ENTITY)와 속성(ATTRIBUTE)]〉, 2020-01-13</ref>
 +
 +
== 분류 ==
 +
; 실체유형(유무형)에 따른 분류
 +
* 유형 엔티티(Tangible Entity)
 +
:물리적인 형태가 존재하는 엔티티이며 안정적이고 지속적으로 활용되는 엔티티이다.
 +
* 개념 엔티티(Conceptual Entity)
 +
:물리적인 형태는 존재하지 않고 관리해야 할 개념적인 정보로 구분이 되는 엔티티이다.
 +
*사건 엔티티(Event Entity)
 +
:업무를 수행함에 따라 발생되는 엔티티이다.<ref name='entity_info2'></ref>
 +
 +
; 발생시점에 따른 분류
 +
* 기본/키 엔티티(Fundamental/Key Entity)
 +
:해당 업무에 원래 존재하는 정보로 다른 엔티티와의 관계에 의해 발생 또는 생성되지 않고 독립적으로 존재하는 엔티티이다. 이는 독립적으로 생성이 가능하며 다른 엔티티의 부모역할을 한다.
 +
* 중심 엔티티(Main Entity)
 +
:기본 엔티티로부터 발생되며 업무에 있어서 중심적인 역할을 한다. 일반적으로 데이터 양이 많으며 다른 엔티티와의 관계를 통해 행위 엔티티를 생성한다.
 +
*행위 엔티티(Active Entity)
 +
:두 개이상의 부모 엔티티로 부터 주로 발생되고, 자주 엔티티의 내용이 바뀌거나 데이터양이 증감한다. 분석초기 단계보다는 상세 설계단계나 프로세스와 상관모델링을 진행하면서 도출될 수 있다.<ref name='entity_info2'></ref>
 +
 +
; 엔티티의 명명
 +
엔티티의 이름을 정하는 데에 있어서는 다음과 같은 원칙을 지켜야 한다.
 +
:가능하면 현업 업무에서 사용하는 용어를 사용한다.
 +
:가능하면 약어를 사용하지 않는다.
 +
:단수 명사를 사용한다.
 +
:모든 엔티티를 통틀어서 유일한 이름을 가져야 한다.
 +
:엔티티의 생성 의미대로 이름을 부여한다.<ref name='entity_info2'></ref>
 +
 +
{{각주}}
  
 
== 같이 보기 ==
 
== 같이 보기 ==
7번째 줄: 44번째 줄:
 
* [[ERD]]
 
* [[ERD]]
  
{{프로그래밍|토막글}}
+
{{데이터|검토 필요}}

2021년 8월 7일 (토) 03:15 기준 최신판

엔티티(entity)는 데이터베이스에서 한 건의 자료를 구성하는 레코드를 말한다. 엔터티라고도 한다. 각 엔티티 간의 관계를 릴레이션(relationship)이라고 하고, 이것을 도표로 나타낸 것을 ERD(Entity Relationship Diagram)라고 한다.

엔티티는 사물의 구조나 상태, 동작 등을 모델로 표현하는 경우, 그 모델의 구성요소를 말한다. 시스템이나 프로그램 등도 하나의 모델로 생각할 수 있다. 이 모델에서, 예를 들면 정보를 통일적·추상적으로 취급할 때, 이 개별 정보를 엔티티라고 부른다. 컴퓨터 시스템 중에서 데이터, 파일, 원시 프로그램(source program), 목적 프로그램(object program) 등도 각각 하나의 엔티티에 해당한다.

개요[편집]

엔티티(entity)는 데이터베이스에 표현하려고 하는 유형, 무형의 객체로서 서로 구별되는 것을 뜻한다. 이 개체는 현실 세계에 대해 사람이 생각하는 개념이나 정보의 단위로서 의미를 가지고 있다. 이것은 컴퓨터가 취급하는 파일의 레코드(record)에 대응한다. 이 개체는 그 단독으로 존재할 수 있으며, 정보로서의 역할을 한다. 하나의 개체는 하나 이상의 속성, 즉 속성(attribute)으로 구성되고 각 속성은 그 개체의 특성이나 상태를 기술해 준다. 예를 들어, 학생이라는 개체는 학번, 이름, 학과라는 3개의 속성들로 구성되어 있다. 이 때 학번, 이름, 학과는 학생이라는 개체가 가지고 있는 특성, 즉 값을 나타내고 있는 것이다. 이와 같이 속성, 즉 속성이라고 하는 것은 이름을 가진, 데이터의 가장 작은 논리적 단위가 된다. 보통 파일 구조에서는 데이터 항목(data item) 또는 필드(field)라고도 한다. 정보의 측면에서 볼 때 이 속성은 그 자체만으로는 중요한 의미를 표현하지 못하기 때문에 단독으로 존재하지는 못한다. 앞의 예에서 각 속성들 즉, 학번, 이름, 학과는 개별적으로는 우리에게 어떤 정보를 제공해 주지 못하지만 이것들이 모여 학생이라는 개체를 구성해서 표현할 때는 큰 의미를 제공하고 있다. 물론 각 속성이 갖는 값은 시간에 따라 변할 수도 있다. 일반적으로, 한 속성이 취할 수 있는 모든 값을 총칭해서 도메인(domain)이라 한다.[1]

특징[편집]

  • 반드시 엔티티가 사용되는 곳의 업무에서 필요하며 관리하고자 하는 정보 엔티티가 포함하는 인스턴스에 대해 유일한 식별자로 식별이 가능해야 한다.
  • 엔티티는 지속적으로 존재하는 두개 이상의 인스턴스들의 조합이어야 한다.
  • 엔티티는 반드시 속성을 지녀야 한다.
  • 엔티티는 업무 프로세스에 의해서 이용되어야 한다.
  • 엔티티는 다른 엔티티와 최소 한 개 이상의 관계가 있어야 한다.[2]

분류[편집]

실체유형(유무형)에 따른 분류
  • 유형 엔티티(Tangible Entity)
물리적인 형태가 존재하는 엔티티이며 안정적이고 지속적으로 활용되는 엔티티이다.
  • 개념 엔티티(Conceptual Entity)
물리적인 형태는 존재하지 않고 관리해야 할 개념적인 정보로 구분이 되는 엔티티이다.
  • 사건 엔티티(Event Entity)
업무를 수행함에 따라 발생되는 엔티티이다.[2]
발생시점에 따른 분류
  • 기본/키 엔티티(Fundamental/Key Entity)
해당 업무에 원래 존재하는 정보로 다른 엔티티와의 관계에 의해 발생 또는 생성되지 않고 독립적으로 존재하는 엔티티이다. 이는 독립적으로 생성이 가능하며 다른 엔티티의 부모역할을 한다.
  • 중심 엔티티(Main Entity)
기본 엔티티로부터 발생되며 업무에 있어서 중심적인 역할을 한다. 일반적으로 데이터 양이 많으며 다른 엔티티와의 관계를 통해 행위 엔티티를 생성한다.
  • 행위 엔티티(Active Entity)
두 개이상의 부모 엔티티로 부터 주로 발생되고, 자주 엔티티의 내용이 바뀌거나 데이터양이 증감한다. 분석초기 단계보다는 상세 설계단계나 프로세스와 상관모델링을 진행하면서 도출될 수 있다.[2]
엔티티의 명명

엔티티의 이름을 정하는 데에 있어서는 다음과 같은 원칙을 지켜야 한다.

가능하면 현업 업무에서 사용하는 용어를 사용한다.
가능하면 약어를 사용하지 않는다.
단수 명사를 사용한다.
모든 엔티티를 통틀어서 유일한 이름을 가져야 한다.
엔티티의 생성 의미대로 이름을 부여한다.[2]

각주[편집]

  1. 환, 〈DB에서 entity란?〉, 2009-12-24
  2. 2.0 2.1 2.2 2.3 Tigercow, 〈엔터티(ENTITY)와 속성(ATTRIBUTE)〉, 2020-01-13

같이 보기[편집]


  검수요청.png검수요청.png 이 엔티티 문서는 데이터에 관한 글로서 검토가 필요합니다. 위키 문서는 누구든지 자유롭게 편집할 수 있습니다. [편집]을 눌러 문서 내용을 검토·수정해 주세요.