테스트 사이트 - 개발 중인 베타 버전입니다

[SQL]Insert 문

· 17년 전 · 3139

9. Insert 문

TABLE에 열을 추가합니다. TABLE에 DATA를 넣는다는 말이죠~!

사용법은 다음과 같습니다.

INSERT INTO student
( name, secure_no, age, birth, city, eng_score, kor_score, math_score )
VALUES
( '최인희', '123456-0123456', 27, '18-JAN-72', 'SUWON', 100, 90, 95' );

사용할 때 가능하면 모든 값을 그 길이만큼 채워서 INSERT할 것을 추천합니다. 왜냐구요? 글세.. 여기서 student는 TABLE 명이고, 괄호안의 것들은 COLUMN NAME입니다.

그러니까 이런 구조네요.

INSERT INTO TABLE_NAME
( COLUMN NAMES )
VALUES
( COLUMN VALUES );

여기에서 COLUMN NAMES의 값들과 COLUMN VALUES의 값들의 수는 일치해야 합니다.

INSERT 문에서 COLUMN VALUES에 들어갈 수 있는 값들은 다음과 같습니다.

  • NULL
  • LITERAL VALUE(정수, 문자.. 모 이런 것~!)
  • 연산자와 함수가 있는 표현식(예를 들면, SUBSTR(lsRemark, 27, 2)같은 것)

물론 위의 세가지 값이 혼용될 수도 있죠.

INSERT 문에서 COLUMN NAMES의 DATA TYPE과 COLUMN VALUES의 DATA TYPE은 일치해야 합니다. 위에서 보면 문자나 날짜는 '로 막고, 숫자는 기냥 썼죠.. 일치하지 않으면 물론 ERROR가 발생합니다. 그리고 물론 TABLE의 CREATE시 지정한 크기를 넘는 DATA를 INSERT 해도 ERROR가 발생합니다.

그리고 PSEUDOCOLUMNS (의사열)이라는 것이 있는데,

  • USER : 현재 ORACLE에 연결되어 있는 USER ID.
  • SYSDATE : 현재 일시.

를 사용하면 편해요. USER는 문자열 COLUMN에 사용할 수 있고, SYSDATE는 DATE형 COLUMN에 사용할 수 있죠.

참~! INSERT할 경우 COLUMN NAMES는 생략할 수도 있어요. 아래와 같이..

INSERT INTO student
VALUES
('최인희', '123456-2123456', 27, '18-JAN-77', 'SUWON', 100, 90, 95');

모든 COLUMN에 INSERT한다는 가정이 포함되죠. 하지만 이건 별로 추천할 만한 방법이 아닌 듯 싶네요.

INSERT 문에서도 SELECT 문에서와 같이 SUB QUERY를 사용할 수 있어요. 그러면 COLUMN VALUES를 지정해서 넣는 대신에 SELECT 문을 사용할 수 있겠죠. 그럼 예를 들어볼까요?

INSERT INTO student
(name, secure_no, age, birth, city, eng_score, kor_score, math_score)
VALUES
SELECT name, secure_no, age, birth, city, eng_score, kor_score, math_score
FROM all_student ;

SUB QUERY를 이용하면 쉽게 많은 데이터를 생성할 수 있을 것 같네요. 테스트 데이터로 활용하면 더 좋겠죠?

쭈~욱 보니까, INSERT 문도 별로 어렵지 않죠? 그럼 담에는 UPDATE 문은 어떻게 사용하나 봐요~!

[이 게시물은 관리자님에 의해 2011-10-31 17:27:00 MySQL에서 이동 됨]

댓글 작성

댓글을 작성하시려면 로그인이 필요합니다.

로그인하기

게시글 목록

번호 제목
29416
13230
13227
13226
13225
13224
25107
13219
13218
13216
13211
13210
29415
13204
13202
29411
13199
13196
13192
13191
13189
13186
29408
13185
13183
13178
13173
13166
13165
13163
13162
13157
13153
13149
13144
13142
13141
13140
13138
13137
13136
25102
13135
13132
13131
13130
13128
13125
13117
13116
13114
13113
13109
13106
13105
13103
13102
13099
13096
13091
29404
13090
13087
29400
13085
13082
29398
13081
13080
13077
25097
13076
13075
13072
13071
29397
13069
13068
13063
13060
25092
25091
25090
13056
13055
13054
29396
13045
13042
13026
13022
13017
13013
13008
13002
12998
25083
12997
29394
29392