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

"테이블 (데이터베이스)"의 두 판 사이의 차이

위키원
이동: 둘러보기, 검색
잔글 (Asadal님이 테이블 (데이터) 문서를 테이블 (데이터베이스) 문서로 이동했습니다)
26번째 줄: 26번째 줄:
 
=== 관계형 데이터베이스 구조 ===
 
=== 관계형 데이터베이스 구조 ===
 
[[파일:릴레이션_구조.png|image]]<ref name='rdb_info'></ref>
 
[[파일:릴레이션_구조.png|image]]<ref name='rdb_info'></ref>
 +
 +
== SQL에서 테이블 활용 ==
 +
=== 테이블 생성===
 +
 +
  CREATE TABLE 테이블 이름 (
 +
        컬럼명1 DATATYPE [DEFAULT 형식],
 +
        컬럼명2 DATATYPE [DEFAULT 형식],
 +
        컬럼명3 DATATYPE [DEFAULT 형식]
 +
  );
 +
 +
:테이블 생성시 대/소문자 구분은 하지 않는다. (기본적으로 테이블이나 컬럼명은 대문자로 만들어진다.)
 +
:DATE 유형은 별도로 크기를 지정하지 않는다.
 +
:문자 데이터 유형은 반드시 가질 수 있는 최대 길이를 표시해야 한다.
 +
:컬럼과 컬럼의 구분은 콤마로 하되, 마지막 컬럼은 콤마를 찍지 않는다.
 +
:컬럼에 대한 제약조건이 있으면 CONSTRAINT를 이용하여 추가할 수 있다.
 +
<ref name='constraint'>개발이 하고 싶어요,〈[https://hyeonstorage.tistory.com/291 CREATE TABLE 테이블 생성, 제약조건(CONSTRAINT), 확인(DESC)]〉, 2014년5월29일</ref>
 +
 +
=== 테이블 수정 ===
 +
 +
  ALTER TABLE 테이블명;
 +
 +
=== 테이블 삭제 ===
 +
  DROP TABLE 테이블명 [CASCADE CONSTRAINT];
 +
 +
:DROP TABLE 명령어를 사용하면 테이블의 모든 데이터 및 구조를 삭제한다.
 +
:CASCADE CONSTRAINT 옵션은 해당 테이블과 관계가 있었던 참조되는 제약조건에 대해서도 삭제한다는 것을 의미한다.
 +
:(SQL Server에서는 CASCADE 옵션이 존재하지 않는다. 테이블 삭제 전에 참조하는 FOREIGN KEY 제약 등을 먼저 삭제해야 한다.)
 +
<ref name='constraint2'>개발이 하고 싶어요,〈[https://hyeonstorage.tistory.com/293 CREATE TABLE 테이블 생성, 제약조건(CONSTRAINT), 확인(DESC)]〉, 2014년5월30일</ref>
 +
 +
=== 테이블 목록 조회 ===
 +
  SHOW TABLES;
 +
 +
=== 테이블 조회 ===
 +
  SELECT * FROM 테이블명;
 +
 +
=== 컬럼 추가 (ADD COLUMN) ===
 +
 +
  ALTER TABLE 테이블명
 +
  ADD 추가할 컬럼명  데이터 유형;
 +
<ref name='constraint3'>개발이 하고 싶어요,〈[https://hyeonstorage.tistory.com/292 CREATE TABLE 테이블 생성, 제약조건(CONSTRAINT), 확인(DESC)]〉, 2014년5월29일</ref>
 +
 +
=== 컬럼 수정 (MODIFY COLUMN) ===
 +
 +
  ALTER TABLE 테이블명
 +
  MODIFY COLUMN 수정할 컬럼명;
 +
 +
:MODIFY COLUMN 사용 시 주의사항
 +
::해당 컬럼의 크기를 늘릴 수는 있지만 줄이지는 못한다. 이는 기존의 데이터가 훼손될 수 있기 때문이다.
 +
::해당 컬럼이 NULL 값만 가지고 있거나 테이블에 아무 행도 없으면 컬럼의 폭을 줄일 수 있다.
 +
::해당 컬럼이 NULL 값만을 가지고 있으면 데이터 유형을 변경할 수 있다.
 +
::해당 컬럼의 DEFAULT 값을 바꾸면 변경 작업 이후 발생하는 행 삽입에만 영향을 미치게 된다.
 +
::해당 컬럼에 NULL 값이 없을 경우에만 NOT NULL 제약조건을 추가할 수 있다.
 +
<ref name='constraint3'></ref>
 +
 +
=== 컬럼명 수정 (RENAME COLUMN) ===
 +
테이블을 생성하면서 만들어졌던 컬럼명을 변경해야 할 경우에 사용한다.
 +
 +
  ALTER TABLE 테이블명
 +
  RENAME COLUMN 변경해야할 컬럼명 TO 새로운 컬럼명;
 +
<ref name='constraint3'></ref>
 +
 +
=== 컬럼 삭제 (DROP COLUMN) ===
 +
 +
  ALTER TABLE 테이블명
 +
  DROP COLUMN 삭제할 컬럼명;
 +
<ref name='constraint3'></ref>
  
 
{{각주}}
 
{{각주}}

2020년 8월 7일 (금) 09:38 판

테이블(table)은 데이터베이스에서 (가로, row, record)과 (세로, column, field)로 짜여진 표에 기록된 데이터의 집합이다.

개요

테이블이란 데이터베이스에서 단일 주제에 관해 행과 열로 구성되는 정보 모음을 가리킨다. 예를 들면, 업무용 데이터베이스는 대개 고객 정보에 관한 테이블을 가지고 있는데, 고객의 계정 번호, 주소, 전화번호 등을 저장할 수 있는 여러 개의 행으로 구성된다. 테이블 내에서 계정 번호 등과 같은 낱낱의 데이터 각각을 필드라고 부른다. 하나의 행은 모든 고객들의 전화 번호 등과 같은 어떤 한 필드 내의 모든 데이터로 구성된다. 필드는 완전한 정보 셋인 레코드로 조직화되며, 각각은 하나의 열을 이룬다. 표준화 과정을 통해 데이터를 가장 효과적인 방법으로 테이블로 구성할 수 있는 방법을 결정한다.

컴퓨터로 만들어지거나 또는 종이 위에 손쉽게 그릴 수 있는 진리표에는 기반이 되는 결정이나 기준 목록을 포함한다. 진리표에는 가능한 모든 결정 상황이 목록화되며, 각 상황에서 취해져야 할 행위가 정의된다. 기본적인 예로는, 도로 교차점의 교통 상황에 대하여 "예" 또는 "아니오"와 같은 결정들과 빨간색 신호나, 녹색 신호 등과 같이 기준들이 표현될 수 있다. 진리표는 여러 가지 상황에서 내려지는 결정에 따라 처리 기준을 지시하기 위한 컴퓨터 프로그램에도 삽입될 수 있다. 진리표가 변경되면 프로그램에도 반영된다.[1]

구조

테이블은 기본적으로 (row)과 (column)으로 구성되어 있다.

행(row)

  • 레코드(record), 튜플(tuple) : 릴레이션이 나타내는 엔티티(entity)의 특정 인스턴스에 관한 사실(값)들의 모임이다. 튜플로 통용된다.
  • 카디날리티(cardinality) : 릴레이션 튜플의 개수[2]

열(column)

  • 속성(attribute) : 하나의 릴레이션은 현실세계의 어떤 개체(entity)를 표현하고 저장되는 데 사용된다. 이때 개체는 사물이 될 수도, 추상적인 개념이 될 수도 있다.
  • 필드(field) : 종종 컬럼의 대용으로 동일한 의미로 사용되지만, 필드와 필드값은 한 열이나 한 컬럼 사이의 교차로 존재하는 단일 항목을 특정할 때 언급하는 것이다.
  • 차수(degree) : 한 릴레이션에 들어 있는 속성의 수[2]

도메인

하나의 속성이 취할 수 있는 같은 타입의 원자값들의 집합이다. 도메인(domain)은 실제 속성 값이 나타날 때 그 값의 합법 여부를 시스템이 검사하는데 이용된다.[2]

릴레이션 인스턴스

릴레이션 인스턴스(relation instance)란 데이터 개체를 구성하고 있는 속성들에 데이터 타입이 정의되어 구체적인 데이터 값을 갖고 있는 것을 말한다.[3]

관계형 데이터베이스 구조

image[2]

SQL에서 테이블 활용

테이블 생성

 CREATE TABLE 테이블 이름 (
       컬럼명1 DATATYPE [DEFAULT 형식],
       컬럼명2 DATATYPE [DEFAULT 형식],
       컬럼명3 DATATYPE [DEFAULT 형식]
 );
테이블 생성시 대/소문자 구분은 하지 않는다. (기본적으로 테이블이나 컬럼명은 대문자로 만들어진다.)
DATE 유형은 별도로 크기를 지정하지 않는다.
문자 데이터 유형은 반드시 가질 수 있는 최대 길이를 표시해야 한다.
컬럼과 컬럼의 구분은 콤마로 하되, 마지막 컬럼은 콤마를 찍지 않는다.
컬럼에 대한 제약조건이 있으면 CONSTRAINT를 이용하여 추가할 수 있다.

[4]

테이블 수정

 ALTER TABLE 테이블명;

테이블 삭제

 DROP TABLE 테이블명 [CASCADE CONSTRAINT];
DROP TABLE 명령어를 사용하면 테이블의 모든 데이터 및 구조를 삭제한다.
CASCADE CONSTRAINT 옵션은 해당 테이블과 관계가 있었던 참조되는 제약조건에 대해서도 삭제한다는 것을 의미한다.
(SQL Server에서는 CASCADE 옵션이 존재하지 않는다. 테이블 삭제 전에 참조하는 FOREIGN KEY 제약 등을 먼저 삭제해야 한다.)

[5]

테이블 목록 조회

 SHOW TABLES;

테이블 조회

 SELECT * FROM 테이블명;

컬럼 추가 (ADD COLUMN)

 ALTER TABLE 테이블명
 ADD 추가할 컬럼명  데이터 유형;

[6]

컬럼 수정 (MODIFY COLUMN)

 ALTER TABLE 테이블명
 MODIFY COLUMN 수정할 컬럼명;
MODIFY COLUMN 사용 시 주의사항
해당 컬럼의 크기를 늘릴 수는 있지만 줄이지는 못한다. 이는 기존의 데이터가 훼손될 수 있기 때문이다.
해당 컬럼이 NULL 값만 가지고 있거나 테이블에 아무 행도 없으면 컬럼의 폭을 줄일 수 있다.
해당 컬럼이 NULL 값만을 가지고 있으면 데이터 유형을 변경할 수 있다.
해당 컬럼의 DEFAULT 값을 바꾸면 변경 작업 이후 발생하는 행 삽입에만 영향을 미치게 된다.
해당 컬럼에 NULL 값이 없을 경우에만 NOT NULL 제약조건을 추가할 수 있다.

[6]

컬럼명 수정 (RENAME COLUMN)

테이블을 생성하면서 만들어졌던 컬럼명을 변경해야 할 경우에 사용한다.

 ALTER TABLE 테이블명
 RENAME COLUMN 변경해야할 컬럼명 TO 새로운 컬럼명;

[6]

컬럼 삭제 (DROP COLUMN)

 ALTER TABLE 테이블명
 DROP COLUMN 삭제할 컬럼명;

[6]

각주

  1. 김동근, 〈table 테이블〉, 《김동근의 텀즈, 컴퓨터 용어사전》, 2002-06-17
  2. 2.0 2.1 2.2 2.3 돌딱, 〈관계형 데이터베이스의 구조〉, 2020-03-18일
  3. 개발자, 〈릴레이션의 특징과 용어〉, 2013년3월16일
  4. 개발이 하고 싶어요,〈CREATE TABLE 테이블 생성, 제약조건(CONSTRAINT), 확인(DESC)〉, 2014년5월29일
  5. 개발이 하고 싶어요,〈CREATE TABLE 테이블 생성, 제약조건(CONSTRAINT), 확인(DESC)〉, 2014년5월30일
  6. 6.0 6.1 6.2 6.3 개발이 하고 싶어요,〈CREATE TABLE 테이블 생성, 제약조건(CONSTRAINT), 확인(DESC)〉, 2014년5월29일

참고자료

같이 보기


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