데이터입출력구현 - 핵심정리

데이터입출력구현

1. 데이터 조작 프로시저 성능 개선

  • 성능 개선 및 자원의 효율적인 사용을 위해 성능 분석 필요
  • 성능 분석 도구
    • 리소스 및 성능 모니터링 : APM
    • SQL 성능 측정 : TKPROF, EXPLAIN PLAN
  • 모니터링 결과 문제시 되는 내용 확인시 SQL 성능 개선 순서
  1. 문제있는 SQL 식별
  2. 옵티마이저 통계 확인
  3. 실행 계획 검토
  4. SQL문을 재구성하거나 인덱스 재구성

데이터입출력구현 - 핵심정리

데이터입출력구현

1. 데이터 조작 프로시저 개발

  • SQL은 관계형 데이터베이스 관리시스템의 데이터를 관리하기 위해 설계된 특수 목적의 프로그래밍 언어로 데이터 정의어, 데이터 조작어, 데이터 제어어를 가짐
  • PL/SQL은 Oracle에서 개발한 데이터 조작 언어이며, 프로그래밍 언어의 특성을 수용한 SQL의 확장 기능이 우수
  • 저장형 객체
    • Trigger
    • Stored Function
    • Stored Procedure
    • Stored Package

2. 데이터 조작 프로시저 테스트

  • Oracle DBMS는 모든 데이터 조작 프로시저에 대한 테스트 환경으로 SQL*Plus 도구를 제공

데이터입출력구현 - 핵심정리

데이터입출력구현

1. 물리데이터모델 설계

  • 논리 데이터 모델로부터 물리 데이터 모델로 변환하는 것은 단위 엔터티를 테이블로, 속성을 칼럼으로 UID를 기본키로, 관계를 외래키로 변환 후 칼럼 유형과 길이 정의
  • 데이터 처리 범위와 빈도 수를 분석하여 반정규화를 고려
  • 반정규화는 중복테이블을 추가하거나 테이블 조합, 분할, 제거 하는 방법 등을 통해 설계

2. 물리 데이터저장소 구성

  • 물리 데이터 모델링 완료 후 모델링 결과에 따라 디스크라는 물리 데이터 저장소에 다양한 오브젝트 구성
  • 테이블, 인덱스, 뷰, 클러스터, 파티션
  • 오브젝트는 디스크 구성 설계를 통해 구성

3. ORM 프레임워크

  • 객체 관계 매핑은 관계형 데이터 베이스와 객체지향 프로그래밍 언어 간의 호환되지 않는 데이터를 변환하는 프로그래밍 기법
  • ORM 절차
    1. 클래스를 테이블로 변환
    2. 속성은 칼럼으로 변환
    3. 클래스간 관계는 관계형 테이블 간의 관계로 변환

4. 트랜잭션 인터페이스

  • 물리 데이터 저장소에서 트랜잭션 인터페이스는 전체적인 데이터베이스 트랜잭션의 골격 및 인터페이스를 정의하는 활동
  • 데이터베이스 트랜잭션 특징
    1. 원자성
    2. 일관성
    3. 독립성
    4. 영속성

통합구현 - 핵심정리

통합구현

1. IDE 도구

  • 통합 개발 환경은 코드의 작성 및 편집, 디버깅, 컴파일, 배포 등 프로그램 개발에 관련된 모든 작업을 하나씩 프로그램 안에서 처리하는 환경을 제공하는 소프트웨어
  • 기능
    1. 개발 환경 지원
    2. 컴파일 및 디버깅 기능 제공
    3. 외부 연계모듈과 통합 기능 제공

2. 협업 도구

  • 종류
    • 기능에 따라 문서굥유
    • 소스 공유
    • 아이디어 공유
    • 디자인 공유
    • 마인드 맵핑
    • 프로제트 관리
    • 일정관리
  • 기능
    1. 개발자간 커뮤니케이션
    2. 일정 및 이슈 공유
    3. 개발자간 집단지성 활용

3. 형상관리 도구

  • 소프트웨어 개발 과정에서 소프트웨어의 변경 사항을 관리하기 위해 변경을 체계적으로 관리, 추적 및 제어하기 위한 일련의 활동
  • 절차
    1. 형상 식별
    2. 변경 제어
    3. 형상 감사
    4. 형상 기록
  • 관리 도구
    • CVS
    • SVN
    • GIT

통합구현 - 핵심정리

통합구현

1. 단위모듈 구현

  • 통합 구현에서 단위 모듈 구현은 비즈니스 컴포넌트, 내외부 인터페이스 모듈, 데이터베이스 접근 모듈 등 통합 구현이 필요한 단위 컴포넌트 구현
  • 고려사항
    1. 응집도는 높히고 결합도는 낮춤
    2. 공통모듈을 먼저 구현
    3. 항상 예외처리 로직을 구려하여 구현

2. 단위모듈 테스트

  • 컴퓨터 프로그래밍에서 소스 코드의 특정 모듈이 의도된 대로 정확히 작동하는지 검증하는 절차
  • 테스트 방법
    1. 화이트박스 테스트
    2. 메소드 기반 테스트
    3. 화면 기반 테스트
    4. 스텁과 드라이버 활용 테스트

제품소프트웨어 패키징 - 핵심정리

제품소프트웨어패키징

1. 소프트웨어 버전 관리 도구

  • 형상관리지침을 활용하여 제품 소프트웨어의 신규 개발, 변경, 개선과 관련된 수정 내역을 관리하는 도구
  • 소프트웨어 버전관리 도구 유형
  1. 공유 폴더 방식 : RCS, SCCS
  2. 클라이언트/서버 방식 : CVS, SVN
  3. 분산 저장소 방식 : Git, Bitkeeper

2. 빌드 자동화 도구

  • 제품 소프트웨어 실행 파일 생성을 자동화하기 위해서 저장소에 있는 소스를 자동으로 읽어서 빌드를 하여 실행 파일을 만드는 도구
  • 온라인 빌드 자동화 도구 : 젠킨스
  • 안드로이드 빌드 도구 : 그래들

제품소프트웨어 패키징 - 핵심정리

제품소프트웨어패키징

1. 제품 소프트퉤어 매뉴얼 작성

  • 제품소프트웨어 매뉴얼은 설치 매뉴얼과 사용자 매뉴얼이 있음
  • 설치 및 사용자 매뉴얼은 개발자의 기준이 아닌 사용자의 기준으로 작성
  • 설치 및 사용자 매뉴얼의 작성 단계와 작성 항목에 대한 이해

2. 국제 표준 제품 품질 특성

  • 제품 품질 표준과 프로세스 품질 표준으로 나뉨
  • 소프트웨어 제품 품질 관련 국제 표준
  • 소프트웨어 프로세스 품질 관련 국제 표준

제품소프트웨어 패키징 - 핵심정리

제품소프트웨어패키징

1. 애플리케이션 패키징

  • 개발이 완료된 소프트웨어를 고객에게 전달하기 위한 형태로 패키징
  • 설치와 사용에 필요한 제번 절차 및 환경 등 전체 내용을 포함하는 매뉴얼을 작성
  • 소프트웨어에 대한 패치 개발과 업그레이드를 위하여 버전 관리를 수행
  • 사용자 관점의 애플리케이션 패키징 고려사항과 애플리케이션 패키징 순서 이해
  • 애플리케이션의 변경 정보가 포함된 릴리즈 노트 개념과 작성항목 이해

2. 애플리케이션 배포 도구

  • 애플리케이션을 배포하기 위한 패키징 시에 디지털 콘텐츠의 지적 재산권을 보호하고 관리하는 기능을 제공하여, 안전한 유통과 배포를 보장하는 도구이자 솔루션
  • 패키징 도구 활용 시 고려사항 이해
  • 저작권 관리의 흐름과 구성 요소 이해

3. 애플리케이션 모니터링 도구

  • 제품 소프트웨어를 사용자 환경에 설치 후 기능 및 성능 운영 현황을 파악하는 도구
  • 애플리케이션 변경관리, 성능관리, 정적분석, 동적분석 도구 등이 있음

애플리케이션테스트케이스설계 - 핵심정리

애플리케이션테스트케이스설계

1. 알고리즘

  • 수학과 컴퓨터 과학, 언어학 또는 관련 분야에서 어떠한 문제를 해결하기 위해 정해진 일련의 절차나 방법을 공식화한 형태로 표현한 것
  • 정렬
    • 선택 정렬
    • 삽입 정렬
    • 버블 정렬
  • 그래프
    • 깊이우선탐색 DFS
    • 너비우선탐색 BFS
  • 탐색
    • 선형 탐색
    • 이진 탐색

2. 애플리케이션 성능 개선

  • 소스코드 최적화는 읽기 쉽고 변경 및 추가가 쉬운 클린 코드를 작성하는 것
  • 클린코드의 작성원칙과 소스코드 최적화 기법
  • 소스코드 품질분석 도구의 이해
  • 정적분석
    • Pmd
    • cppcheck
    • SonarQube
    • Checkstyle
  • 동적분석
    • Avalanche
    • valgrind

애플리케이션테스트케이스설계 - 알고리즘

애플리케이션테스트케이스설계

  • 정렬
    • 선택 정렬
    • 삽입 정렬
    • 버블 정렬
  • 그래프
    • 깊이우선탐색 DFS
    • 너비우선탐색 BFS
  • 탐색
    • 선형 탐색
    • 이진 탐색

Github Repository
Notion 개념정리

API API오용 Anaconda Beacon Bluetooth CRUD분석 Camera ChatBot DB관련신기술 DB관리기능 DB서버 DB표준화 ER다이어그램 ER모델 ETL Flask HW관련신기술 IDE도구 IP IoT Machine_Translation NLP배경 ORM프레임워크 Package Recurrent Neural Network SDLC SW개발방법론 SW개발방법론선정 SW개발보안정책 SW개발표준 SW관련신기술 Sequence_Tagging ShellScript TCP_UDP Vector WordCloud c 자료형 class embedding konlpy python python 자료형 가설검증 개발환경구축 객체지향프로그래밍언어 관계데이터베이스모델 관계데이터언어 국제표준제품품질특성 네트워크7계층 네트워크관련신기술 네트워크장비 네트워크침해공격용어 논리데이터모델개요 논리데이터모델품질검증 논리적데이터모델링 논문 단위모듈구현 단위모듈테스트 데이터검증 데이터모델개념 데이터베이스무결성 데이터베이스백업 데이터베이스암호화 데이터베이스용량설계 데이터베이스이중화구성 데이터베이스정규화 데이터분석 데이터분석 - 순열 - 조합 데이터분석 - 정규분포 데이터분석 - 통계기초 데이터사이언스개념 데이터입출력 데이터전환수행계획 데이터정제 데이터조작프로시저작성 데이터조작프로시저최적화 데이터조작프로시저테스트 데이터지역화 데이터타입 데이터표준확인 데이터품질분석 라이브러리 로그분석 메모리관리 모델화 몬테카를로 물리데이터모델설계 물리데이터모델품질기준 물리데이터저장소구성 물리요소조사분석 반정규화 배치프로그램 변수 보안기능 보안솔루션 보안아키텍처 보안취약성식별 분산데이터베이스 분산분석 비용산정모델 빌드자동화도구 사용자정의함수 상관분석 서버개발프레임워크 서버인증 서버장비운영 서버접근통제 서비스공격유형 선언형언어 세션통제 소스코드인스펙션 소프트스킬 소프트웨어개발프레임워크 소프트웨어버전관리도구 소프트웨어연계테스트 슈퍼디엠지 스크립트언어 시스템카탈로그와뷰 암호알고리즘 애플리케이션모니터링도구 애플리케이션배포도구 애플리케이션성능개선 애플리케이션테스트결과분석 애플리케이션테스트시나리오작성 애플리케이션테스트케이스작성 애플리케이션통합테스트수행 애플리케이션패키징 연산자 예외처리 오답노트 오류데이터측정 오류처리 오류처리확인및보고서작성 요구공학방법론 운영체제 웹서버 이벤트 인터넷구성의개념 인터페이스구현검증 인터페이스기능확인 인터페이스보안 입력데이터검증및표현 자료구조 자연어처리 재사용 절차적프로그래밍언어 정보보안침해공격용어 정보처리기사 제품소프트웨어매뉴얼작성 집계성DCL작성 체크리스트 초기데이터구축 취약점분석 칼럼속성 캡슐화 코드오류 클러스터링 키종류 테일러링기준 트랜잭션인터페이스 트리거 파일처리기술 파티셔닝 패키지 포트포워딩 프로세스스케줄링 프로토타입 한국어임베딩 핵심정리 현업도구 형상관리도구 환경변수 회귀분석
Your browser is out-of-date!

Update your browser to view this website correctly. Update my browser now

×