지구정복

[SQLD] 14. DML (Data Manipulation Language) 본문

자격증 정복/SQLD

[SQLD] 14. DML (Data Manipulation Language)

nooh._.jl 2020. 11. 9. 22:45
728x90
반응형

1. INSERT

  1. 테이블에 데이터를 입력(한번에 한건만 입력)
    1. 첫번째 테이블의 컬럼을 정의하는 방법은 테이블 컬럼순서와 매치할 필요는 없으며 정의하지 않은 컬럼은 디폴트로 NULL값이 입력된다.(Primary Key나 Not NULL로 지정된 컬럼일 경우 에러 발생)
    2. 두번째 유형은 테이블에 정의된 컬럼의 순서대로 빠짐없이 데이터가 입력되어야 한다.
  2. 문자형 데이터 유형의 경우 '' 안에 데이터를 입력한다.
  3. NULL이나 ''를 통해 정의되지 않은 미지의 값을 입력할 수 있다.

2. UPDATE

  1. 입력된 데이터를 수정
  2. 예제

3. DELETE

  1. 데이터를 삭제
  2. 예제
    1. FROM 구문은 생략이 가능
    2. WHERE 절을 사용하지 않을시 테이블의 모든 데이터가 삭제

4. DML과 DDL

  1. DDL은 직접 데이터베이스의 테이블에 영향을 미치기 때문에 DDL을 입력하는 순간 즉시 AUTO COMMIT된다.
  2. DML은 조작하는 데이터를 메모리 버퍼에 올려 작업하기 때문에 실제 테이블에 변경이 반영되기 위해서는 COMMIT 명령어를 입력하여 TRANSACTION을 종료해야 한다.
    1. SQL Server의 경우 DML도 AUTO COMMIT 된다.
  3. 테이블의 전체 데이터를 삭제하는 경우 시스템 활용 측면에서는 시스템 부하가 적은 TRUNCATE TABLE을 권고한다.
    1. DELETE는 삭제된 데이터를 로그에 저장하는 작업을 한다.
    2. TRUNCATE TABLE은 로그를 저장하지 않으므로 ROLLBACK이 불가능하다.
    3. SQL Server의 경우 TRUNCATE TABLE문 역시 ROLLBACK 구문을 통해 되돌릴 수 있다.

5. SELECT

  1. 사용자가 입력한 데이터를 조회하는 명령
  2. 예제
    1. ALL/DISTINCT 옵션
    2. WILDCARD 사용: 테이블에서 모든 컬럼 정보를 보고 싶을 경우 * 사용
    3. 컬럼 ALIAS 부여
      1. 컬러명 바로 뒤에 온다.(컬럼명과 ALIAS사이에 AS ,as 키워드 사용 가능)
      2. "" 사이에 넣은 ALIAS명은 공백, 특수문자포함, 대소문자 구분이 필요할때 사용한다.(SQL Server의 경우 "", '', [] 모두 사용 가능하다.)

6. 산술 연산자와 합성 연산자

  1. 산술 연산자
    1. NUMBER ,DATE 자료형에 대해 적용
    2. 일반적은 수학에서의 4칙 연산과 동일(우선순위도 동일: (), *, /, + -)
    3. 우선순위를 위한 괄호 적용이 가능
    4. 산술 연산자 사용시 컬럼 LABEL이 길어지게 되므로 적절한 ALIAS를 부여하는 것이 좋다.
    5. 예제

  2. 합성 연산자
    1. 문자와 문자를 연결한다.(리포트 출력시 유용하다.)
    2. 2개의 수작바(||)에 의해 이루어진다.(ORACLE)
    3. SQL Server의 경우 + 표시에 의해 이루어진다.
    4. 두 벤더 모두 CONCAT(string1, string2) 함수 사용이 가능하다.
    5. 컬럼과 문자 혹은 컬럼과 컬럼을 연결 가능하다.

       

정리

------DML
----INSERT : 컬럼명에 데이터값 집어넣기(한 번에 한건만 입력)
INSERT INTO 테이블명 (컬럼명들)
VALUES (컬럼에 넣을 데이터값들);

INSERT INTO 테이블명
VALUES (전체 컬럼에 넣을 데이터값들);

----UPDATE : 입력된 데이터를 수정
UPDATE 테이블명
SET 컬럼명 = 수정할데이터값;

----DELETE : 데이터를 삭제 WHERE절 사용하지 않으면 모든 데이터 삭제
DELETE [FROM] 테이블명
[WHERE]

----SELECT : 사용자가 입력한 데이터를 조회하는 명령
--DISTINCT 중복된 데이터가 있는 경우 1건으로 처리한다.
SELECT [ALL | DISTINCT] 보고싶은컬럼명1, 보고싶은컬럼명2
FROM 해당컬럼들이있는 테이블
[WHERE]
[CHECK]
[ORDER BY]
[GROUP BY]
[HAVING]

--모든 컬럼 보고 싶을 경우
SELECT *
FROM 테이블명;

--컬럼 alias 부여
SELECT PLAYER_NAME "선수 이름", POSITION "그라운드 포지션", HEIGHT "키", WEIGHT "몸무게"
FROM PLAYER;

--산술연산자
SELECT PLAYER_NAME 이름, ROUND(WEIGHT/( (HEIGHT/100)*(HEIGHT/100) ) , 2) "BMI 비만지수"
FROM PLAYER;

--합성연산자
SELECT PLAYER_NAME||'선수,'||HEIGHT||'cm,'||WEIGHT||'kg,'체격정보
FROM PLAYER;

 

 

 

 

 

[출처]

wiki.gurubee.net/display/STUDY/3.DML%28DATA+MANIPULATION+LANGUAGE%29?

728x90
반응형
Comments