반응형
Notice
Recent Posts
Recent Comments
Link
지구정복
[SQLD] 14. DML (Data Manipulation Language) 본문
728x90
반응형
1. INSERT
- 테이블에 데이터를 입력(한번에 한건만 입력)
- 첫번째 테이블의 컬럼을 정의하는 방법은 테이블 컬럼순서와 매치할 필요는 없으며 정의하지 않은 컬럼은 디폴트로 NULL값이 입력된다.(Primary Key나 Not NULL로 지정된 컬럼일 경우 에러 발생)
- 두번째 유형은 테이블에 정의된 컬럼의 순서대로 빠짐없이 데이터가 입력되어야 한다.
- 문자형 데이터 유형의 경우 '' 안에 데이터를 입력한다.
- NULL이나 ''를 통해 정의되지 않은 미지의 값을 입력할 수 있다.
2. UPDATE
- 입력된 데이터를 수정
- 예제
3. DELETE
- 데이터를 삭제
- 예제
- FROM 구문은 생략이 가능
- WHERE 절을 사용하지 않을시 테이블의 모든 데이터가 삭제
4. DML과 DDL
- DDL은 직접 데이터베이스의 테이블에 영향을 미치기 때문에 DDL을 입력하는 순간 즉시 AUTO COMMIT된다.
- DML은 조작하는 데이터를 메모리 버퍼에 올려 작업하기 때문에 실제 테이블에 변경이 반영되기 위해서는 COMMIT 명령어를 입력하여 TRANSACTION을 종료해야 한다.
- SQL Server의 경우 DML도 AUTO COMMIT 된다.
- 테이블의 전체 데이터를 삭제하는 경우 시스템 활용 측면에서는 시스템 부하가 적은 TRUNCATE TABLE을 권고한다.
- DELETE는 삭제된 데이터를 로그에 저장하는 작업을 한다.
- TRUNCATE TABLE은 로그를 저장하지 않으므로 ROLLBACK이 불가능하다.
- SQL Server의 경우 TRUNCATE TABLE문 역시 ROLLBACK 구문을 통해 되돌릴 수 있다.
5. SELECT
- 사용자가 입력한 데이터를 조회하는 명령
- 예제
- ALL/DISTINCT 옵션
- WILDCARD 사용: 테이블에서 모든 컬럼 정보를 보고 싶을 경우 * 사용
- 컬럼 ALIAS 부여
- 컬러명 바로 뒤에 온다.(컬럼명과 ALIAS사이에 AS ,as 키워드 사용 가능)
- "" 사이에 넣은 ALIAS명은 공백, 특수문자포함, 대소문자 구분이 필요할때 사용한다.(SQL Server의 경우 "", '', [] 모두 사용 가능하다.)
- ALL/DISTINCT 옵션
6. 산술 연산자와 합성 연산자
- 산술 연산자
- NUMBER ,DATE 자료형에 대해 적용
- 일반적은 수학에서의 4칙 연산과 동일(우선순위도 동일: (), *, /, + -)
- 우선순위를 위한 괄호 적용이 가능
- 산술 연산자 사용시 컬럼 LABEL이 길어지게 되므로 적절한 ALIAS를 부여하는 것이 좋다.
- 예제
- 합성 연산자
- 문자와 문자를 연결한다.(리포트 출력시 유용하다.)
- 2개의 수작바(||)에 의해 이루어진다.(ORACLE)
- SQL Server의 경우 + 표시에 의해 이루어진다.
- 두 벤더 모두 CONCAT(string1, string2) 함수 사용이 가능하다.
- 컬럼과 문자 혹은 컬럼과 컬럼을 연결 가능하다.
정리
------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
반응형
'자격증 정복 > SQLD' 카테고리의 다른 글
[SQLD] 16. WHERE절 (0) | 2020.11.09 |
---|---|
[SQLD] 15. TCL (Transaction Control Language) (0) | 2020.11.09 |
[SQLD] 13. DDL (Data Defintion Language) (0) | 2020.11.09 |
[SQLD] 12. 관계형 데이터베이스 개요 (0) | 2020.11.09 |
[SQLD] 11. 분산 데이터베이스와 성능 (0) | 2020.11.09 |
Comments