728x90

DATABASE

    [DB] 이상 현상(Anomaly) 개념, 종류

    이상 현상(Anomaly) 중복이 발생하고 전체적인 무결성이 저하 릴레이션에 대한 데이터 삽입, 수정, 삭제 연산을 할 때 발생할 수 있는 부작용 현실세계의 실제 값과 데이터베이스에 저장된 값이 일치하지 않는 문제가 발생 정규화를 통해 해결 기본 테이블 예시) 학교 테이블 1. 삽입 이상(Insertion Anomaly) 특정 데이터가 존재하지 않아 중요한 데이터를 데이터베이스에 삽입할 수 없을 때 발생 내가 원하는 값만 테이블에 삽입하고 싶은데, 테이블에 필요하지 않은 필드들 때문에 원치 않는 필드의 값도 삽입해야 하는 경우 신설된 '수학과'에는 학생이 존재하지 않아 테이블에 '수학과' 데이터를 추가할 수 없음 정규화를 통해 학생 테이블과 학과 테이블로 분리하면 해결 가능 2. 삭제 이상((Deleti..

    [DB] 데이터베이스 기초 용어, 키(Key)의 개념과 종류

    데이터베이스 기초 용어 릴레이션(Relation) 관계형 데이터 모델에서 하나의 개체에 관한 데이터를 저장하기 위한 구조 (= 테이블) 스키마와 인스턴스로 이루어짐 스키마(Schema) 릴레이션의 이름, 각 속성의 이름, 타입, 도메인 등을 정의하는 개념 인스턴스(Instance) 릴레이션에 저장되는 데이터(튜플)의 집합 속성(Attribute) 릴레이션의 열(Column) 서로 다른 이름을 가져야 함 튜플(Tuple) / 레코드(Record) 릴레이션의 행(Row) 중복 불가 차수(Degree) 하나의 릴레이션에서 속성의 전체 개수 카디널리티(Cardinality) 하나의 릴레이션에서 튜플의 전체 개수 도메인(Domain) 릴레이션의 속성이 가질 수 있는 원자값들의 집합 키(Key) 릴레이션의 튜플을 ..

    [DB] 트랜잭션(Transaction) 개념, 특징, 연산, 상태

    트랜잭션(Transaction) 데이터베이스의 상태를 변화시키는 하나의 논리적 기능을 수행하기 위한 작업의 단위 한꺼번에 수행되어야할 일련의 연산 데이터베이스 일관성과 무경성 보장 데이터베이스의 하나의 작업이 수행되는 동안 다른 작업이 간섭하지 못하도록 함 논리적인 작업 셋을 모두 완벽하게 처리하거나 또는 처리하지 못할 경우에는 원 상태로 복구해서 작업의 일부만 적용되는 현상이 발생하지 않게 만들어주는 기능 트랜잭션 연산 Commit 하나의 트랜잭션이 성공적으로 끝나서 데이터베이스가 일관성 있는 상태에 있음을 알려주기 위해 사용하는 연산 Rollback 하나의 트랜잭션 처리가 비정상적으로 종료되어 데이터베이스의 일관성을 깨뜨렸을 때, 이 트랜잭션의 일부가 정상적으로 처리되었더라도 트랜잭션의 원자성을 보장..

    [DB] RDBMS의 SQL과 NoSQL 차이

    관계형 데이터베이스(RDBMS, SQL Database) 고정된 행(row)과 열(column)로 구성된 테이블에 데이터를 저장 테이블의 관계가 구조화된 데이터의 모음이기 때문에 구조화된 쿼리 언어(SQL)를 사용하여 데이터를 다룸 각 열은 하나의 속성에 대한 정보를 저장하고, 행에는 각 열의 데이터 형식에 맞는 데이터가 저장 테이블의 구조와 데이터 타입 등을 사전에 정의한 후 그 형식을 유지하며 데이터 조작 테이블 간의 관계를 직관적으로 파악할 수 있음 장점 명확하게 정의된 스키마, 데이터 무결성 보장 관계는 각 데이터를 중복없이 한번만 저장 단점 데이터 스키마를 변경하기 어려워 유연성이 떨어짐 관계를 맺고 있어서 Join 문이 많은 복잡한 쿼리가 만들어질 수 있음 대체로 수직적 확장만 가능함 비관계형..

    [DB] 인덱스(Index) 개념, 장단점, 전략, 구조

    인덱스(Index) 책의 '색인'과 같이 데이터베이스 내 데이터 검색 성능을 높이기 위해 사용하는 자료 구조 특정 칼럼에 인덱스를 생성하면, 해당 칼럼의 데이터를 정렬하여 별도의 메모리 공간에 데이터의 물리적 주소와 함께 저장 데이터를 검색하는 쿼리를 실행하면 옵티마이저는 인덱스에 저장되어 있는 데이터의 물리 주소를 참조하면서 검색 속도 향상 인덱스 생성 시 데이터를 오름차순으로 정렬 장점 검색 조건 WHERE 절에서의 효율성 인덱스를 설정하지 않으면 뒤죽박죽 섞여있는 데이터 중 검색을 하려면 풀 스캔(Full Scan)을 해야함 인덱스 테이블은 데이터들이 정렬되어 저장되어 있기 때문에 조건(WHERE절)에 맞는 데이터를 빠르게 찾을 수 있음 정렬 ORDER BY 절에서의 효율성 인덱스를 사용하면 이미 ..

    [DB] SQL SELECT 쿼리 문법 순서와 실행 순서

    SQL의 SELECT 쿼리문이 어떤 순서로 실행이 되는지를 알면 올바르고 효율적인 쿼리를 짜는데에 많은 도움이 된다. 따라서 SQL 문법 순서와 실제 실행 순서를 다음과 같이 정리해 본다. 💎 SQL 문법 순서 SELECT FROM WHERE GROUP BY HAVING ORDER BY 💎 SQL 실제 실행 순서 FROM : 각 테이블 확인 ON : 조인 조건 확인 JOIN : 테이블 조인 (병합) WHERE : 데이터 추출 조건 확인 GROUP BY : 특정 칼럼으로 데이터 그룹화 HAVING : 그룹화 이후 데이터 추출 조건 확인 SELECT : 데이터 추출 DISTINCT : 중복 제거 ORDER BY : 데이터 정렬

728x90