생성
create table 테이블명(
no number constraint 테이블명_pk_no primary key,
name varchar2(40)
);

생성과 동시에 데이터 복사
create table copy_tb as select * from ori_tb;

기존 테이블에 데이터만 가져오기
insert into copy_tb select * from ori_tb;

<<<<<<<<<<<  sysdate >>>>>>>>>>>

현재의 시간과 날자를 반환한다.

//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
<<<<<<     실     습 1 ::  date(날짜) data type을 갖는 table 생성     >>>>>>
1. sequence test용 table생성
create table sysdate_test01(
 no number primary key,
 regdate date
);


2. 2000년 10월 1일 입력하기
insert into sysdate_test01(no,regdate)
values(1,'2000-10-1');

//=> table에서 확인
select * from sysdate_test01;

//=> 현재의 시간을 sysdate을 이용하여 입력
insert into sysdate_test01(no,regdate)
values(2,sysdate);

//=> table에서 확인
select * from sysdate_test01;


4. 다른 방법으로 sequnce 확인하기

//==> 현재의 sequence value 확인
select seq_seq_test01_no.CURRVAL from dual;

//==> 다음의 sequence value 확인
select seq_seq_test01_no.NEXTVAL from dual;

//==>확인하면
insert into seq_test01(no,remark)
values(seq_seq_test01_no.NEXTVAL,'연습1');

select * from seq_test01;


//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
<<<<<<     실     습  2 :: date(날짜) data type  Java에서 처리  >>>>>>

varchar2  ===> rs.getString("columnName");
number  ===> rs.getInt("columnName");
date  ===> rs.getDate("columnName");  또는
date  ===>rs.getTimestamp("columnName");

시퀀스 조회
select * from user_sequences;

시퀀스 값조회
select seq_bbs_no.currval from dual;

시퀀스 생성
create sequence seq_테이블 이름-필드이름
 increment by n   <== 증가값 (default 1)
 start with n   <== 시작값 (default 1)
 maxvalue n | nomaxvalue  <== 최고값 (nomaxvalue default 10*E27)
 minvalue n | nominvalue  <== 최소값 (nominvalue default 1)
 cycle | nocycle   <== 최소,최고값이후 값의 생성유무 (default nocycle)
 cache | nocache   <== 메모리에 유지할 값의 수 (default 20)

시퀀스 삭제
drop sequence seq_bbs_no;


<<<<<<<<<<<  Sequence >>>>>>>>>>>

1. 자동으로  Unique number 생성
2. 공유가능한 Object
3. 일반적으로 Primary key값을 생성키 위해 사용

[ Syntax ]
create sequence seq_테이블 이름-필드이름
 increment by n   <== 증가값 (default 1)
 start with n   <== 시작값 (default 1)
 maxvalue n | nomaxvalue  <== 최고값 (nomaxvalue default 10*E27)
 minvalue n | nominvalue  <== 최소값 (nominvalue default 1)
 cycle | nocycle   <== 최소,최고값이후 값의 생성유무 (default nocycle)
 cache | nocache   <== 메모리에 유지할 값의 수 (default 20)

 

//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
<<<<<<     실     습 1 ::  sequence default생성     >>>>>>
1. sequence test용 table생성
create table seq_test01(
 no number primary key,
 remark varchar2(10)
);


2. default로 sequence 생성
create sequence seq_seq_test01_no;


3.seq_test01 table에 값 insert후 확인하기
insert into seq_test01(no,remark)
values(seq_seq_test01_no.NEXTVAL,'연습1');

//=> table에서 확인
select no,remark from seq_test01;

//=> 반복 실행하면
insert into seq_test01(no,remark)
values(seq_seq_test01_no.NEXTVAL,'연습2');

select no,remark from seq_test01;


4. 다른 방법으로 sequnce 확인하기

//==> 현재의 sequence value 확인
select seq_seq_test01_no.CURRVAL from dual;

//==> 다음의 sequence value 확인
select seq_seq_test01_no.NEXTVAL from dual;

//==>확인하면
insert into seq_test01(no,remark)
values(seq_seq_test01_no.NEXTVAL,'연습1');

select * from seq_test01;


//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
<<<<<<     실     습  2 :: sequence의 삭제 및 변경   >>>>>>

[Syntax]
drop sequence sequence_name;

drop sequence seq_seq_test01_no;

+ Recent posts