안녕하세요 정보처리기사 필기를 준비하고 있는 3구입니다. 저는 A부분 중요한 부분만 포스팅하겠습니다.

 

1. 소프트웨어 생명 주기 (Software Life Cycle) or 소프트웨어 수명 주기

 소프트웨어 생명 주기는 소프트웨어 개발 방법론의 바탕이 되는 것으로, 소프트웨어 개발하기 위해 정의하고 운용, 유지보수 등의 과정을 각 단계별로 나눈 것이다.

  • 소프트웨어 생명 주기는 소프트웨어 개발 단계와 각 단계별 주요 활동, 그리고 활동의 결과에 대한 산출물로 표현한다.

  • 개발자는 문제의 유형이나 개발 방법 등에 따라 특정 모형을 선택하여 사용할 수 있고, 개별적인 모형을 사용할 수도 있다.

  • 소프트웨어 생명 주기에는 폭포수 모형, 프로토타입 모형, 나선형 모형, 애자일 모형 등이 있다.

2. 폭포수 모형(Waterfall Model)

 폭포수 모형은 소프트웨어 개발도 이전 단계로 돌아갈 수 없다는 전제하에 있습니다. 즉, 처음부터 조립해서 물건을 만들었는데 조립한 뒤 분해할 수 없다는 것입니다.

  • 소프트웨어 공학에서 가장 오래되고 가장 폭넓게 사용된 소ㅍ프트웨어 생명 주기 모형, 고전적 생명 주기 모형이라고도 함

  • 소프트웨어 개발 과정의 한 단계가 끝나야만 다음 단계로 넘어갈 수 있는 선형 순차적 모형이다.

  • 제품의 일부가 될 매뉴얼을 작성해야 한다.

  • 각각의 단계가 끝난 후 다음 단계를 수행하기 위한 결과물이 명확하게 산출 되어야 한다.

  • 두 개 잏상의 과정이 병행하여 수행되지 않는다.

타당성 검토 -> 계획 -> 요구 분석 -> 설계 -> 구현(코딩) -> 시험(검사) -> 유지보수

 

3. 프로토 타입(Prototype Model, 원형 모형)

 프로토타입 모형은 사용자의 요구사항을 정확히 파악하기 위해 실제 개발될 소프트웨어에 대한 견본(시제)품을 만들어 최종 결과물을 예측하는 모형이다.

  • 시제품은 사용자와 시스템 사이의 인터페이스 중점을 두어 개발

  • 시트템의 모형을 만드는 과정으로서 요구된 소프트웨어를 구현하는데, 이는 추후 구현 단계에서 사용될 골격 코드가 된다.

  • 개발이 완료된 시점에서 오류가 발견되는 폭포수 모형의 단점을 보안하기 위한 모형이다.

4. 나선형 모형(Spiral Model, 점진적 모형)

 나선형 모형은 보헴(Boehm)이 제안한 것으로, 폭포수 모형과 프로토타입 모형의 장점에 위험 분석 기능을 추가한 모형이다.

  • 나선을 따라 돌듯이 소프트웨어 개발 과정을 여러번 반복하면서 진행하는 개발 방법, 점진적 모형이라고도 함

  • 위험을 관리하고 최소화하는 것을 목적

  • 개발 과정이 반복되므로 누락되거나 추가된 요구사항을 첨가할 수 있고, 정밀하며, 유지보수 과정이 필요 없다.

계획 및 정의 -> 위험 분석 -> 공학적 개발 -> 고객 평가

 

5. 애자일 모형(Agile Model)

  애자일은 '민첩한', '기만한'이라는 의미로, 고객의 요구사항 변화에 유연하게 대응할 수 있도록 일정한 주기를 반복하면서 개발과정을 진행한다.

  • 애자일 모형은 고객의 다양한 요구사항의 변화에 유연하게 대응하기 위해 일정한 개발 주기를 반복하는 것이 핵심!!

  • 고객과의 소통에 초점을 맞춘 방법론

  • 스프린트(Sprint) , 이터레이션(Iteration)이라고 불리는 짧은 개발 주기를 반복하며, 반복되는 주기마다 만들어지는 결과물에 대한 고객의 평가와 요구를 적극 수용한다.

  • 고객의 요구사항에 우선순위를 부여하여 개발 작업을 진행

  • 소규모 프로젝트, 고도로 숙달된 개발자, 급변하는 요구사항에 적합

  • 애자일 모형을 기반으로 하는 소프트웨어 개발 모형이는 스크럼(Scrum), XP(eXtrem Programming), 칸반(Kanban), Lean, 크리스탈(Crystal), ASD(adaptive Software Development), FDD(Feature Driven Develpment), DSDM(Dynamic System Develpment Method), DAD(Disciplined Agile Delivery)등이 있다.

애자일 개발 4가지 핵심 가치

  1. 프로세스와 도구보다는 개인과 상호작용에 더 가치를 둔다.

  2. 방대한 문서보다는 실행되는 Sw에 더가치를 둔다.

  3. 고객과 협업에 더 가치를 둔다

  4. 변화에 반응하는 것에 더 가치를 둔다.

6. 폭포수 모형과 애자일의 비교

구분 폭포수 모형 애자일
새로운 요구사항 반영 어려움 지속적으로 반영
고객과의 의사소통 적음 지속적임
테스트 마지막에 모든 기능을 테스트 반복되는 일정 주기가 끝날 때마다 테스트
개발 중심 계획, 문서(매뉴얼)

고객

 

애자일 개발 12가지 실행 지침

  1. 고객을 만족시킨다.

  2. 요구사항 변경을 적극 수용한다.
  3. 주 단위로 실행되는 소프트웨어를 제공
  4. 프로젝트 기간에 함께 일한다. (고객, 개발자)
  5. 의자가 확실한 사람들로 팀을 구성, 개발 환경과 지원을 제공, 일을 잘 끝낼 수 있도록 신뢰
  6. 얼굴을 맞대고 의견을 낸다.
  7. 1차 기준은 작동하는 소프트웨어인지 확인
  8. 일정한 속도로 개발을 진행한다.
  9. 관심을 기울이면 민첩성이 향상된다.
  10. 단순화를 추구한다.
  11. 자기 스스로 일을 주도하는 조직적인 팀으로부터 나온다.
  12. 효과적인 팀이 될 수 있는 방안을 정기적으로 깊이 고민하고 그에 따라 팀의 행동을 조정한다.

음... 애자일 개발은 못 할 것 같네요^^ 전,,

이상포스터를 마치겠습니다.

테이블(Table)이란?

테이블은 데이터베이스의 가장 기본적인 객체로 로우(Row, 행)와 컬럼(Column, 열)으로 구성되어 있습니다. 

- 테이블은 논리 설계 단계의 개체(Entity)에 대응하는 객체이다.

 

클러스터드 인덱스 테이블(Clustered Index Table)이란?

기본키(Primary Key)나 인덱스키의 순서에 따라 데이터가 저장되는 테이블

- 인덱스를 사용하는 테이블에 비해 접근 경로가 단축된다.
학번 이름 학과 학년
20132812 김철수 경영학과 3
20142222 김민수 컴퓨터공학과 4
20152838 김춘삼 회계학과 2
20182999 남지원 물리치료학과 1

클러스터드 인덱스 테이블은 데이터가 기본키인 '사원번호'필드를 기준으로 정렬되어 저장된다.

 

파티셔닝 테이블(Partitioning Table)이란? 

- 대용량의 테이블을 작은 논리적 단위인 파티션(Partition)으로 나눈 테이블

- 대용량의 데이터를 효과적으로 관리할 수 있지만 파티션 키를 잘못 구성하면 성능 저하 드의 역효과를 초래할 수 있다.

- 파티셔닝 방식에 따라 범위 분할(Range Partitioning), 해시 분할(Hash Partitioning), 조합 분할(Composite Partitioning) 등으로 나뉜다.

- 범위 분할(Range Partitioning) : 지정한 열의 값을 기준으로 분할

- 해시 분할(Hash Partitioning) : 해시 함수를 적용한 결과 값에 따라 데이터를 분할

- 조합 분할(Compostie Partitioning) : 범위 분할로 분할 한 다음 해시 함수를 적용하여 다시 분할하는 방식

<파트1> 테이블

학번 이름 입학날짜 학과
20203943 김오리 2020-03-03 경영학과
20143495 김화석 2014-03-03 경영학과
20103333 김암모 2010-03-02 통계학과

 

<파트2> 테이블 

학번 이름 입학날짜 학과
20213943 김구라 2021-03-03 경영학과
20203495 김지영 2020-03-03 경영학과

'입사일자' 필드르 기준으로 연도별 파티셔닝 되었다. 

 

외부 테이블(Txternal Table)이란?

- 데이터베이스에서 일반 테이블처럼 이용할 수 있는 외부 파일로, 데이터베이스 내에 객체로 존재한다.

- 데이터웨어하우스(Data Warehouse)에서 ETL(Extraction, Tarnsformation, Loading) 등의 작업에 유용하게 사용된다.

- 데이터웨어하우스(Data Ware-house) : 조직이나 기업체의 중심이 되는 주요 업무 시스템에서 추출되어 새로이 생성된 데이터베이스, 의사결정지원시스템을 지원하는 주체적, 통합적, 시간적 데이터의 집합체를 말한다.

- ETL(Extraction, Transformation, Loading) : 데이터웨어하우스를 사용 하여 추출(Extract), 변환(Transform), 적재(Load)하는 일련의 모든 과정

임시 테이블(Temporary Table)이란?

트랜잭션 이나 세션별로 데이터를 저장하고 처리할 수 있는 테이블

- 임시 테이블에 저장된 데이터는 트랜잭션이 종료되면 삭제된다.

- 임시 테이블은 절차적인 처리를 위해 임시로 사용하는 테이블

- 트랜잭션(Transaction) - 데이터베이스의 상태를 변환시키는 하나의 논리적 기능을 수행하기 위한 작업의 단위 or 한꺼번에 모두 수행되어야 할 일련의 연산들

 

컬럼(Column)이란?

테이블의 열을 구성하는 요소로 데이터 타입(Data Type), 길이(Length) 등으로 정의

- 데이터의 일관성 유지를 위해 사용되는 가장 기본적인 것, 도메인을 정의한 경우 도메인에 따라 데이터의 타입과 길이가 정의된다.

- 두 컬럼의 데이터 타입이나 길이가 다르면 DBMS 내부적으로 데이터 타입을 변한한 후 비교 연산을 수행한다.

- 참조 관계인 컬럼들은 데이터 타입과 길이가 일치해야 된다.

- 데이터 타입과 길이 지정 시 고려사항
   1. 가변 길이 데이터 타입 : 에상되는 최대 길이로 정의
   2. 고정 길이 데이터 타입 : 최소 길이로 지정
   3. 소수점 이하 자릿수 : 소수점 이하 자릿수는 반올림되어 저장

- 데이터 타입에 따른 컬럼의 물리적인 순서
  1. 고정 길이 컬럼이고 NOT Null인 컬럼 : 앞쪽
  2. 가변 길이 컬럼 : 뒤쪽
  3. Null 값이 많을 것으로 예상되는 컬럼 : 뒤쪽

 

테이블스페이스(Tablespace)이란? 

테이블이 저장되는 논리적인 영역, 하나의 테이블 스페이스에 하나 or 그 이상의 테이브을 저장할 수 있다.

- 테이블을 저장하면 논리적으로는 테이블스페이스에 저장되고, 물리적으로는 해당 테이블스페이스와 연관된 데이터 파일(Data File)에 저장된다.

- 테이블베이스를 테이블, 테이블스페이스, 데이터 파일로 나눠 관리하면 논리적 구성이 물리적 구성에 종속되지 않아 투명성이 보장된다.

- 데이터베이스에 저장되는 내용에 따라 테이블, 인덱스, 임시(Temporay)등의 용도로 구분하여 설계한다. 

- 테이블스페이스 설계 시 고려사항
   1. 업무별로 구분하여 지정
   2. 대용량 테이블은 하나의 테이블스페이스에 독립적으로 저장한다.
   3. 테이블과 인덱스는 분리하여 저장한다.
   4. LOB(Large Object) 타입의 데이터는 독립적인 공간으로 지정

- 투명성 : 어떠한 사실이 존재함에도 마치 투명하여 보이지 않는 것

- LOB (Large Object)는 대용량의 데이터를 저장할 수 있는 데이터 타입

이상포스터를 마치겠습니다.

+ Recent posts