[Oracle 기본사용법][02] CREATE(테이블 생성),INSERT(데이터 삽입)
"생활코딩 Oracle"을 개인 공부 후 자료를 남기기 위한 목적이기에 내용 상에 오류가 있을 수 있습니다.
목표
- SQL언어란 무엇인고 장점에대해 공부합니다.
- Oracle SQL Plus 에서 테이블을 생성하고 데이터를 삽입을 실습합니다.
*해당 글의 실습은 Oracle XE버젼을 환경을 바탕으로 진행 행하였습니다.
목차
0. SQL언어
1. 테이블 생성(CREATE TABLE)
2. 데이터 삽입(INSERT INTO)
0. SQL언어
- Structured Query Language 구조화된 정보를 처리하도록 요청하는 컴퓨터 언어
- 데이터베이스 제어할 수 있는 언어입니다.
- 수많은 데이터베이스 절대다수는 '관계형 데이터베이스'를 사용하고 있습니다. 관계형 데이터베이스는 오직 SQL 언어로만 제어가 가능합니다.
- 따라서 SQL을 사용할 줄 아는 것은 절대다수의 시스템에서 동작하는 컴퓨터 언어를 이해한다는 것입니다. => 매우 가성비가 높은 언어
- SQL 언어 장점
- 매운 큰 성능을 가집니다.
=> 액셀과 같은 스프레드 시트는 행을 추가하는데 한계가 있습니다. 하지만 데이터베이스
로 분류되는 시스템에서는 저장장치의 한계가 없다면 엄청나게 많은 데이터를 처리할
수 있습니다.
- 명령어를 통해서 데이터베이스를 제어할 수 있다는 점입니다. 이 말의 함의하는 바는 "자동화"가 가능하다는 점입니다.
* 만들고자 하는 테이블
테이블 이름 : topic
id | title | description | created |
1 | ORACLE | ORACLE is ... | 2020.04.03 |
2 | MySQL | MySQL is .... | 2020.04.03 |
3 | NoSQL | NoSQL is ... |
이번 글은 Sql Plus를 통해 위의 표를 만드는 것을 목표로 합니다.
1.테이블 생성하기
CREATE TABLE 테이블이름 (
컬럼명 데이터타입 제약조건,
컬럼명 데이터타입 제약조건,
컬럼명 데이터타입 제약조건,
);
- 컬럼명 뒤에 데이터타입은 반드시 있어야 한다.
- 제약조건은 있어도 되고 없어도 된다.
- 데이터를 삽입시 각 칼럼에 정의되어진 데이터 타입과 제약조건을 만족하지 않으면 에러를 발생시킵니다.
실습
1. sql plus를 실행 후 사용자 접속을 합니다.
- 방법 1 : 윈도우 [시작]에 들어가서 설치한 Oracle 목록을 보시면 해당프로그램이 있습니다.
- 방법 2 : cmd창에 들어가서 'sqlplus'를 치시면 프로그램이 실행됩니다.(그림 1-1)
2. 테이블을 만드는 SQL명령문을 처넣은 후 Enter를 칩니다.
CREATE TABLE topic(
id NUMBER NOT NULL,
title VARCHAR2(50) NOT NULL,
description VARCHAR(4000),
created DATE NOT NULL
);
- 칼럼명은 id, title, description, created가 만들어지고 각각의 데이터 타입은 NUMBER[숫자], VARCHAR2(50)[최대크기 50 가변문자], VARCHAR2(4000)[최대그기 4000 가변문자] , DATE[날짜형식] 이 지정되었습니다.
- NOT NULL은 해당 칼럼은 NULL을 허용하지 않는다는 뜻입니다.(반드시 데이터가 존재해야 함)
- NULL을 허용 시 데이터 타입 뒤에 "NULL"을 기입해도 되고 생략해도 됩니다.
3. '테이블이 생성되었습니다'라는 문구가 뜨면 정상적으로 테이블이 만들어진 거지만, 아래의 문장을 치고 enter를 처서 데이터베이스 해당 테이블을 검색합니다.
SELECT table_name from user_tables;
- 사용자가 만들 테이블(user_tables) 로부터 테이블 이름(table_name)을 요청합니다 라는 의미입니다.
- 결과는 다음과 같이 나옵니다.
2. 데이터 삽입
INSERT INTO 테이블명(컬럼1, 컬럼2, 컬럼3....)
VALUES (값1, 값2, 값3......);
- 테이블명(칼럼)과 VALUES(값)의 개수는 일치하여야 합니다. 그렇지 않은 경우 에러가 납니다.
- 값은 테이블에 정의된 데이터 타입이 삽입이 되어야 합니다. 그렇지 않은 경우 에러가 납니다.
실습
1. Sql Plus에서 아래의 문장을 처넣은 후 Enter를 치면 삽입이 진행됩니다.
INSERT INTO topic (id, title, description, created) values (1, 'ORACLE', 'ORACLE is...', SYSDATE);
INSERT INTO topic (id, title,description,created) values (2, 'MySQL', 'MySQL is...', SYSDATE);
INSERT INTO topic (id, title,description,created) values (3, 'NoSQL', 'NoSQL is...', SYSDATE);
- topic 테이블에 있는 칼럼 id, title, description, created에 값 1, 'ORACLE', 'ORACLE is...', SYSDATE를 넣는다는 의미입니다.(첫문장)
- SYSDATE는 해당 데이터베이스에서 제공하는 함수입니다. 삽입 명령이 이루어지는 시간이 자동적으로 입력됩니다.
2. 위의 명령어가 정상적으로 진행되었으면 해당 명령의 확정을 위해서 "commit;"를 칩니다.
- 모든 작업을 정상적으로 처리하겠다고 확정하는 명령어 입니다.
- Transaction(insert, update, delete)작업 내용을 실제 DB에 저장됩니다.
- commit 명령을 하지않고 종료시엔 실제 DB엔 기록이 되어있지 않습니다.
3. 테이블을 만들어졋고 데이터가 정상적으로 삽입되었는지 확인해보기 위해 아래의 명령어를 사용하용합니다.
SELECT * FROM topic;
- 는 해당 테이블이 가지고 있는 모든 칼럼을 말합니다.
- topic 테이블에 있는 모든 데이타을 가지고 와라는 뜻입니다.
- [그림2-3]의 결과를 보면 각 행 단위로 데이터 결과가 나온것을 확인할 수 있습니다.
Reference
Date
- 2020.04.04 작성