스키마, 도메인, 테이블, 뷰, 인덱스 등 데이터의 구조를 정의하거나 제거
CREATE, ALTER, DROP이 있다.
CREATE TABLE [테이블명] ( 속성 );
DROP TABLE [테이블명];
스키마, 도메인, 테이블, 뷰, 인덱스 등 데이터의 구조를 정의하거나 제거
ALTER TABLE [테이블명] ADD [속성이름] [타입]; ALTER TABLE [테이블명] DROP [속성이름] [CASCADE]; ALTER TABLE [테이블명] RENAME COLUMN [속성이름] to [변경이름]; ALTER TABLE [테이블명] MODIFY [속성이름] [타입];
[참조할 테이블명]_[참조할 컬럼명]으로 네이밍하고 아래와 같이 참조해준다.
FOREIGN KEY (컬럼명) REFERENCES [참조할 테이블명] (참조할 컬럼명)
실질적으로 데이터를 조회 삽입, 삭제, 수정할 때 사용하는 SQL
SELECT DELETE UPDATE INSERT가 있다.
INSERT INTO [테이블명] ([컬럼 값(자동삽입 값 제외하고 명시)]) VALUES ([명시한 컬럼과 맞는 순서의 속성]);
UPDATE [테이블명] SET [컬럼명]=[바꿀 값] WHERE [조건식]
DELETE FROM [테이블명] WHERE [조건식]
ORDER BY [컬럼명] ASC(오름차순) or DESC(내림차순), 다음정렬;
SELECT [컬럼명 or *] from [테이블명] WHERE [조건식]
컬럼을 유형별로 그룹화 할 때 사용하며 WHERE이 아닌, HAVING으로 조건을 건다
GROUP BY를 사용하려면 반드시 SELECT 문에 집계함수만 있거나, GROPU BY 뒤에 명시해줘서 그룹화 할 수 있어야 한다.(추가)
GROUP BY [컬럼명] HAVING [조건식]
사용자가 id, pwd에 다음과 같이 입력한다면?
id: ewqewq1' = '1' OR '1' = '1'##
pwd: ewqewq

실제 실무에서는 하나의 테이블에서만 값을 가져오지 않고 여러 테이블의 값을 조회한다.
테이블을 먼저 합치고, WHERE절로 원하는 값을 가져온다.
지정한 값과 같은 값만 join


왼쪽에 기준이 되는 테이블을 출력하고 오른쪽에 지정한 값과 일치하는 테이블 값을 출력한다.


오른쪽에 기준이 되는 테이블을 출력하고 왼쪽에 지정한 값과 일치하는 테이블 값을 출력한다.

