부트캠프(END)/Oracle에 해당하는 글 19

  1. DML, TCL 2022.06.28

    DML(Data Manipulation Language,데이터 조작 언어) 테이블에 있는 데이터를 조작하는 언어이다. 데이터를 추가하거나, 수정하거나, 삭제할 수 있다. - INSERT~INTO : 데이터 추가 ex) 게시물 생성, 회원 가입, 댓글 달기, 예매, 장바구니 추가 등... INSERT ALL 의 경우 default가 존재하더라도 입력값을 설정해 주어야 한다. INSERT INTO table_name VALUES(value1, value2,...) INSERT INTO table_name(column_name1, column_name2) VALUES(value1, value2..) - UPDATE~SET : 데이터 수정 ex) 게시물 수정, 회원정보 수정, 댓글 수정, 장바구니 수량 변경 등..


  2. DDL 예제 2022.06.28

    판매 전표, 제품, 전표 상세에 대한 총 3개의 테이블을 만들어 본다. 개념적 설계 (어떤 값들을 저장해야 하는가?) → 논리적 설계 (추출했을 때 어떤 데이터형으로 받아올 것인가?) → 물리적 설계 (실제 메모리 크기는 어떻게 지정할 것인가?) CREATE, CONSTRAINT 기본적인 구조를 생성한다. --판매전표 / 전표번호(PK), 판매일자, 고객명, 총액 CREATE TABLE receipt( id varchar2(12), --20220628-001 이런느낌~ rdate DATE, client_name varchar2(34), total_price NUMBER ) --제품 / 제품번호(PK), 제품명, 제품단가 CREATE TABLE product( id varchar2(12), name var..


  3. 서브쿼리, ROWNUM, 인라인뷰, DDL 2022.06.27

    https://gent.tistory.com/287 [Oracle] 오라클 ANY, SOME, ALL 연산자 사용법 완벽 정리 오라클의 ANY, SOME, ALL 연산자는 실무에서 자주 사용은 안하지만, 사용법이 궁금해서 찾아보면 사용법이 생각보다 어렵고 어떤 상황의 쿼리문에서 사용해야 할지 머릿속에 그려지지 않는다. SOME gent.tistory.com 스칼라 서브 쿼리 SELECT *, (SELECT deptno FROM dept WHERE dept.NO = emp.deptno) FROM emp; ROWNUM 행에 번호를 매겨 준다. 데이터가 INSERT된 순서대로 번호가 정해 진다. LIMIT처럼 사용할 순 있으나 행 번호를 먼저 정한 뒤 정렬을 진행하므로 다르다. 정렬을 진행한 SELECT문을 ..


  4. Oracle JOIN, ANSI JOIN 2022.06.22

    EQUI_JOIN : 연산자 =을 써서 조인 NON_EQUI_JOIN : AND, OR, BETWEEN 등을 포함하여 조인 --EQUI_JOIN SELECT empno, ename, job, sal, dname, loc, grade FROM emp e JOIN dept d ON e.deptno = d.deptno --NON_EQUI_JOIN SELECT empno, ename, job, sal, dname, loc, grade FROM emp e JOIN salgrade s ON sal BETWEEN losal AND hisal Oracle JOIN : 오라클에서만 사용하는 조인 (MySQL도 가능) ANSI JOIN : 표준화된 조인 ANSI JOIN에 대한 내용은 여기 --Oracle INNER JO..


  5. Oracle 내장 함수 2022.06.21

    LENGTH : 문자의 길이를 반환한다. SELECT LENGTH('ABC'), LENGTH('코딩공부블로그') --각각 3, 7 출력 FROM DUAL; --테이블 없이 계산 출력/함수 확인용 연습테이블(오라클) UPPER : 대문자로 변환 ↔ LOWER : 소문자로 변환 INITCAP : 맨 앞글자만 대문자로 변환 SELECT UPPER('abC'), --ABC LOWER('ABc'), --abc INITCAP('something good can work') --Something Good Can Work FROM DUAL; *REPLACE(문자열, 바꿀 문자, 바뀔 문자) :문자열의 특정 문자를 다른 문자로 변경 *SUBSTR(문자열, 시작위치, 자를 문자 수) : 문자열을 원하는 위치에서 추출 시작..


  6. NVL, LIKE, ORDER BY + JDBC예제 2022.06.20

    *MySQL과 다른 부분을 중심으로 정리 NVL(Null VaLue) 오라클에서 모든 연산자는 인자 중 null 값이 있는 경우 연산 결과로 null을 반환한다. → null값 처리가 필요하다. → postgreSQL에서는 coalesce()를 사용했지만, 오라클에서는 NVL을 사용한다. NVL(컬럼명, 대체할 값) 으로 간단하게 처리 가능하다. 아래 쿼리로 확인~ SELECT salary , comm , salary+comm , NVL(comm, 0) , salary+(NVL(comm,0)) FROM employee; LIKE, REGEXP_LIKE 문자열의 패턴을 비교할 때 사용한다. postgreSQL이나 MySQL과 거의 비슷하게 사용된다. 관련글 (참고로 오라클에서 escape는 이렇게 수행함)..


  7. 데이터베이스(Database) 2022.06.17

    데이터 : 관찰의 결과로 나타난 정량적/정성적인 실제 값 정보 : 데이터에 의미를 부여한 것 데이터를 정보화하는 작업이 중요하고, 이 작업을 쉽게 하기 위해 데이터베이스가 활용된다. → 데이터베이스 = 필요한 정보를 얻기 위해 논리적으로 연관된 데이터를 모아 구조적으로 통합해 놓은 것 데이터베이스 시스템(DBMS)은 데이터의 검색과 변경 작업을 주로 수행한다. 변경 = 시간에 따라 변하는 데이터 값을 데이터베이스에 반영하기 위해 수행하는 작업(삽입, 삭제, 수정 등) 오라클은 응용 프로그램과 실제 데이터를 연결해 주는 역할. 실제 데이터는 하드디스크에 저장되며, 데이터베이스 시스템을 통해 응용 프로그램이 데이터를 사용할 수 있게 된다. 데이터베이스의 특징 1. 실시간으로 접근이 가능하다. 2. 계속적인 ..


  8. JDBC 맛보기 2022.06.15

    Music.java package doodoo.vo; import java.io.Serializable; import lombok.Getter; import lombok.Setter; @Getter @Setter public class Music implements Serializable{ private int mno; // 고유번호(시퀀스) private int cno; // 카테고리 번호 private String title; // 곡명 private String poster; // 포스터 private String singer; // 가수명 private String album; // 앨범명 private int idcrement; // 등폭 private String state; // 상태 } M..


  9. Oracle 설치 및 세팅(Windows x64) 2022.06.15

    Oracle Database XE https://www.oracle.com/database/technologies/xe18c-downloads.html Oracle SQL Developer https://www.oracle.com/tools/downloads/sqldev-downloads.html Oracle 삭제시 참고 msiexec /x {C220B7FD-3095-47FC-A0C0-AE49DE6E320A} SQL Plus 관리자 권한으로 실행 후 --계정 만들기 alter session set "_ORACLE_SCRIPT"=true; create user {$username} identified by {$password}; --권한 부여 grant create session to {$username}..