Backend
[DB] DDL :: ALTER , DROP
✍ALTER : 객체를 수정하는 구문 표현식 테이블 객체 수정 ALTER TABLE 테이블명 수정할 내용; 👉수정할 내용 컬럼 추가/수정/삭제, 제약조건 추가/삭제 컬럼 자료형 변경, DEFAULT값 변경 테이블명 변경, 컬럼명, 제약조건 이름 변경 🚩 1. 컬럼 추가, 수정, 삭제 1) 컬럼 추가(ADD) ALTER TABLE 테이블명 ADD (새로운컬럼명 데이터타입(크기)) ➡ ADD 뒤에 COLUMN 생략가능 ➡ 새로운 컬럼이 추가되었지만 데이터는 없기 때문에 값이 NULL이다. 1-1) 컬럼 추가 시 DEFAULT값 지정 ALTER TABLE 테이블명 ADD (새로운컬럼명 데이터타입(크기) DEFAULT 기본값) 2) 컬럼 수정(MODIFY) 데이터 타입, 기본값(DEFAULT) 수정 ALTER ..
![[DB] TCL(TRANSGACTION CONTROL LANGUAGE)](https://img1.daumcdn.net/thumb/R750x0/?scode=mtistory2&fname=https%3A%2F%2Fblog.kakaocdn.net%2Fdn%2FcqGYHu%2FbtrfUQJMVZK%2FmbcDZpBVLMgb6bTekbSYK1%2Fimg.png)
[DB] TCL(TRANSGACTION CONTROL LANGUAGE)
더보기 목차 1. COMMIT 2. ROLLBACK 3. SAVEPOINT ✍TCL(TRANSGACTION CONTROL LANGUAGE) Transgaction : 데이터베이스의 논리적 연산 단위 TCL : 트랜잭션 제어 언어 데이터의 변경 사항을 묶어 하나의 트랜잭션에 담아 처리한다. 트랜잭션에 담겨지는 대상이 되는 SQL : INSERT, UPDATE, DELETE (DML, 데이터 조작 언어) SQL DEVELOPER에서 INSERT, UPDATE, DELETE 작성 시 바로 DB에 반영되는것이 아니라 메모리 임시버퍼에서 COMMIT 해야 DB에 반영된다. COMMIT한 것을 없애고 싶을 때 : ROLLBACK SVAPOINT S1을 중간 저장한다고 했을 때 ROLLBACK TO S1시 SAVEP..
![[DB] DDL : CREATE, 제약조건 CHECK](https://img1.daumcdn.net/thumb/R750x0/?scode=mtistory2&fname=https%3A%2F%2Fblog.kakaocdn.net%2Fdn%2FcVVezV%2FbtrfPik0HmV%2FKa0UAjYPTZtOMzwHah9Lk0%2Fimg.png)
[DB] DDL : CREATE, 제약조건 CHECK
더보기 목차 1. CREATE 2. 제약조건(CONSTAINT) 1) PRIMARY KEY, NOT NULL, UNIQUE, FOREIGN KEY, CHECK 4. DELETE 데이터 딕셔너리란? : 자원을 효율적으로 관리하기 위한 다양한 정보를 저장하는 시스템 테이블 데이터 딕셔너리는 사용자가 테이블을 생성하거나 사용자를 변경하는 등의 작업을 할 때 데이터베이스 서버에 의해 자동으로 갱신되는 테이블 참고) User_tables : 자신의 계정이 소유한 객체 등에 관한 정보를 조회 할 수 있는 딕셔너리 뷰 SELECT * FROM USER_TABLES; 으로 결과를 볼 수 있다. ✍DDL(Data Definition Language) : 데이터 정의 언어 객체(OBJECT)를 만들고(CREATE), 수정..
[DB] DML (INSERT, UPDATE, MERGE, DELETE)
더보기 목차 1. INSERT 2. UPDATE 3. MERGE 4. DELETE ✍DML(Data Manipulation Language) : 데이터 조작 언어 테이블에 값을 삽입하거나(INSERT), 수정하거나(UPDATE), 삭제(DELETE)하는 구문 COMMIT, ROLLBACK 할 때 주의❗ 종류 SELECT INSERT UPDATE DELETE 🚩 INSERT 테이블에 새로운 행을 추가하는 구문 1) ⭐ INSERT INTO 테이블명 VALUES(데이터, 데이터, ...)⭐ : 테이블에 모든 컬럼에 대한 값을 추가할 때 사용하는데 INSERT하고자 하는 컬럼이 모든 컬럼인 경우 컬럼명 생략 가능하다. INSERT INTO 테이블명 VALUES(데이터1, 데이터2, 데이터3); 결과) 1 행 ..
[DB] SUBQUERY
더보기 목차 1. 단일행 (+ 단일열) 서브쿼리 (SINGLE ROW SUBQUERY) 2. 다중행 서브쿼리 (MULTI ROW SUBQUERY) 3.(단일행) 다중열 서브쿼리 4. 다중행 다중열 서브쿼리 5. 상[호연]관 서브쿼리 6. 스칼라 서브쿼리 7. 인라인 뷰(INLINE-VIEW) 8. WITH 9. RANK() OVER / DENSE_RANK() OVER ✍SUBQUERY( 서브쿼리) 하나의 SQL문 안에 포함된 또다른 SQL문 메인쿼리(기존쿼리)를 위해 보조 역할을 하는 쿼리문 SELECT, FROM, WHERE, HAVGIN 절에서 사용가능 : SELECT 문장 안에 포함된 또 다른 SELECT 문장으로 메인 쿼리가 실행되기 전 한 번만 실행된다. 비교 연산자의 오른쪽(WHERE절,GRO..
[DB] JOIN
더보기 목차 1. INNER JOIN (내부조인) 2. OUTER JOIN (외부조인) 1) LEFT [OUTER] JOIN 2) RIGHT [OUTER] JOIN 3) FULL [OUTER] JOIN 3. CROSS JOIN (교차 조인) 4. NON EQUAL JOIN (비등가 조인) 5. SELF JOIN (자체 조인) 6. NATURAL JOIN (자연 조인) 7. 다중 조인 [ JOIN 용어 정리 ] 오라클 SQL : 1999표준(ANSI) 등가 조인 (= 을 사용하기 때문에) 내부 조인(INNER JOIN), JOIN USING / ON + 자연 조인(NATURAL JOIN, 등가 조인 방법 중 하나) 포괄 조인 왼쪽 외부 조인(LEFT OUTER), 오른쪽 외부 조인(RIGHT OUTER) ..
![[DB] SELECT문 해석 순서 | GROUP BY, ORDER BY,HAVING, 집계 함수](https://img1.daumcdn.net/thumb/R750x0/?scode=mtistory2&fname=https%3A%2F%2Fblog.kakaocdn.net%2Fdn%2FlRFQN%2FbtrfzkcdfOt%2FO4MUfemsrdnNqkQzGq92AK%2Fimg.png)
[DB] SELECT문 해석 순서 | GROUP BY, ORDER BY,HAVING, 집계 함수
⭐ SELECT문 해석 순서 ⭐ 5: SELECT 컬럼명 | 계산식 | 함수 AS 별칭 1: FROM 참조할 테이블명 2: WHERE 컬럼명 | 함수식 비교연산자 비교값 3: GROUP BY 그룹으로 묶을 컬럼명 4: HAVING 그룹함수식 비교연산자 비교값 6: ORDER BY 컬럼명 | 별칭 | 컬럼순서 [ASC|DESC] [NULLS FIRST | LAST]; 확인필요) SELECT, WHERE, GROUP BY, HAVING 에는 서브쿼리가 들어갈 수 있다. 예제. EMPLOYEE 테이블에서 부서별 급여 합, 급여 평균(소수점 아래 둘째 자리 반올림), 인원 수를 부서코드 오름차순으로 조회 SELECT DEPT_CODE, SUM(SALARY) "급여 합", ROUND( AVG(SALARY) ,1 ..
![[DB] 함수(Function)_단일행, 그룹](https://img1.daumcdn.net/thumb/R750x0/?scode=mtistory2&fname=https%3A%2F%2Fblog.kakaocdn.net%2Fdn%2FyJRTE%2Fbtre0czOIxf%2FStd51lrZXah1k5J7pC4wv0%2Fimg.png)
[DB] 함수(Function)_단일행, 그룹
✍함수(Function) : 하나의 큰 프로그램에서 반복적으로 사용되는 부분들을 분리하여 작성해 놓은 작은 서브 프로그램 호출하며 값을 전달하면 결과를 리턴하는 방식으로 사용 데이터가 모여지는 기반으로 데이터를 한 곳에 모은다. 단일행 함수(SINGLE ROW) : 컬럼에 기록된 N개의 값을 읽어 N개의 결과를 반환 각 행마다 반복적으로 적용되어 입력 받은 행의 개수만큼 결과 반환 그룹 함수(SINGLE ROW) : 컬럼에 기록된 N개의 값을 읽어 1개의 결과를 반환 특정 행들의 집합으로 그룹이 형성되어 적용됨 그룹 당 1개의 결과 반환 함수가 적용될 수 있는 위치 : SELECT절, WHERE절, ORDER BY절, GROUP BY절, HAVING절 단일행 함수 🚩 문자처리 함수 1. LENGTH 주어..
![[DB] SQL, DML(SELECT),연산자,WHERE, DISTINCT, ORDER BY](https://img1.daumcdn.net/thumb/R750x0/?scode=mtistory2&fname=https%3A%2F%2Fblog.kakaocdn.net%2Fdn%2FInhWx%2FbtreZ1jBn6D%2FEmLO2qZDVmvC3USQ9zfB1k%2Fimg.png)
[DB] SQL, DML(SELECT),연산자,WHERE, DISTINCT, ORDER BY
✍SQL(Structured Query Language) : 구조적 / 질의 / 언어 == 구조적인 질의를 하기 위한 언어 관계형 데이터베이스(RDBMS)에서 데이터를 조회하거나 조작하기 위해 사용하는 언어 원하는 데이터를 찾는 방법이나 절차를 기술하는 것이 아닌 조건을 기술하여 작성 ⭐중요⭐ ➡ DML (Data Manipulation Language) : 데이터 조작(조회, 삽입, 수정, 삭제) ➡ 숫자: 정수 실수 구분없이 숫자이다 ➡ 문자 : 똑같은 가변길이 문자이더라도 LONG보다는 용량이 더 큰 CLOB을 많이 쓴다. 🚩 SELECT : 조회 SELECT문을 이용하여 데이터를 조회하는 경우 알맞은 조회 결과의 묶음인 RESULT SET이 반환된다. 참고) DML > DQL SELECT는 DML..
![[DB|Oracle] 개발환경 기초 설정, CREATE·GRANT](https://img1.daumcdn.net/thumb/R750x0/?scode=mtistory2&fname=https%3A%2F%2Fblog.kakaocdn.net%2Fdn%2FNN0BY%2FbtreZZ65xtf%2Fw9BUVDNTz3Qa6TTNiuHLZK%2Fimg.png)
[DB|Oracle] 개발환경 기초 설정, CREATE·GRANT
1. 문자 인코딩은 전세계 공통인 UTF-8로 설정한다. 도구 - 환경설정 - Environment - 인코딩(E) 2. 접속 설정 파일( 또는 왼쪽 상단의 + ) – 새로 만들기 – General – 접속 – 데이터베이스 접속 sys as sysdba 접속 설정 sys as sysdba : 데이터 베이스 최고 관리 권한을 행할 수 있는 계정 sys : 최고 권한을 가지고 있는 계정 as sysdba : 관리자 권한을 행사 ① 접속 이름 : 관리자 (자유롭게 지정) ② 사용자 이름 : sys as sysdba 비밀번호 : oracle ③ 테스트 클릭 ④ 접속 상태 확인 -> 상태: 성공 ⑤ 비밀번호 저장 체크, 접속 색상 지정 ⑥ 저장 클릭 후 좌측 창에 등록 확인 ⑦ 접속 클릭 관리자 계정 관리 용도의..