백엔드/SQL 첫걸음 8

8. 데이터베이스 설계

34. 데이터베이스 설계 데이터베이스 설계터이터베이스의 스키마 내에 테이블, 인덱스, 뷰 등의 데이터베이스 객체를 정의, 테이블 간의 관계를 고려해 테이블 이름, 열, 자료형을 결정스키마 내에 정의한다는 의미에서 '스키마 설계'라고 부르기도 함 | 물리명: CREATE TABLE에 지정하는 테이블 이름아니 열 이름 | 논리명: 설계상의 이름 | 수치 자료형: 금액이나 개수와 같은 수치 데이터만 다룰 수 있는 열 | 문자열형: 제조번호와 같이 알파벳을 다루는 데이터 LOB(Large Object)문자열형에서 주로 사용하는 VARCHAR형보다 담을 수 있는 용량이 큰 문자열단, 인덱스를 지정할 수 없다는 제약이 있음 AUTO_INCREMENT기본키로 지정할 열이 생각나지 않는 경우 자동증가 열을 사용해 기본..

7. 복수의 테이블 다루기

31. 집합 연산 SQL과 집합SELECT 명령을 실행하면 데이터베이스에 질의, 그 결과로 몇 개의 행이 출력되는 과정이때, 반환된 결과 전체를 하나의 집합으로 보고 집합 내 하나의 행을 하나의 요소로 간주 UNION집합의 연산 중 '합집합'을 위해 사용하는 명령어합집합이란 집합을 서로 더하는 것을 의미하며 A∪B와 같이 표현SQL에서 SELECT 명령의 실행 결과를 하나의 집합으로 다룰 수 있으며 UNION은 다음과 같이 표현mysql> SELECT * FROM t1;mysql> SELECT * FROM t2;mysql> SELECT * FROM t1; UNION SELECT * FROM t2; // 집합의 합집합 연산* 합집합 시, 동일 행은 한 개만 출력: 각각의 SELECT 명령의 열의 내용은 서..

6. 데이터베이스 객체 작성과 삭제

25. 데이터베이스 객체 데이터베이스 객체테이블이나 뷰, 인덱스 등 데이터베이스 내에 정의하는 모든 것을 일컫는 말이때, 객체는 데이터베이스 내에서 실체와 이름을 가지며 데이터베이스 내에서 객체를 작성할 때는 이름이 겹치지 않도록 해야 함 데이터베이스 객체의 명명규칙 및 제약 사항- 기존 이름이나 예약어와 중복하지 않는다.- 숫자로 시작할 수 있다.- 언더스코어 외 기호는 사용 불가하다- 한글을 사용할 때는 더블쿼트로 둘러싼다.- 시스템이 허용하는 길이를 초과하지 않는다. 스키마객체의 이름이 같아도 스키마가 서로 다르다면 상관없으며 데이터베이스 객체는 스키마 객체라 불리기도 함SQL 명령의 DDL을 이용하여 정의하며 어떤 것이 스키마가 되는지는 데이터베이스 제품에 따라 다름 - 스키마 설계: 실제로 데이..

5. 집계와 서브쿼리

20. 행 갯수 구하기 집계: 집합으로 부터 하나의 값을 계산하는 과정집계 함수: 하나의 행에 대해 하나의 값을 반환하는 일반적인 함수와 다르게 복수의 값에서 하나의 값을 계산* SELECT 구문에서의 집계함수는 WHERE 구의 유무와 관계없이 결과값으로 하나의 행을 반환 집계함수 [집합] 형태로 사용하며 대표적인 집계함수는 다음과 같음- COUNT, SUM, AVG, MIN, MAX... COUNT인수로 지정된 집합의 행 개수를 반환mysql> SELECT COUNT(*) FROM t1; // 테이블 전체의 행 개수 반환mysql> SELECT COUNT(*) FROM t1 WHERE name='A'; // WHERE구의 조건에 해당하는 행의 개수 반환* SELECT보다 WHERE 구를 먼저 처리하므로..

4. 데이터의 추가, 삭제, 갱신

16. 행 추가하기 INSERT행을 추가하는 함수mysql> INSERT INTO t1 VALUES (1,'ABC','2024-10-05');mysql> INSERT INTO t1 (a,b) VALUES ('XYZ',2); // a,b열만 지정해 행 추가 NOT NULL 제약NOT NULL 제약이 걸려있는 열은 NULL 값을 허용하지 않음 DAFUALT명시적으로 값을 지정하지 않은 경우 사용하는 초기값을 의미테이블을 정의할 때 지정할 수 있으며 열을 지정해 행을 추가할 때 지정하지 않은 열은 Deafult 값을 사용하여 저장mysql> INSERT INTO t1 (a,b) VALUES(2,DEFAULT); // 명시적으로 DEFAULT를 지정해 INSERT 17. 삭제하기 DELETEDELETE FROM..

3. 정렬과 연산

09. 정렬 ORDER BYSELECT [원하는 열] FROM [table name] WHERE [조건] ORDER BY [원하는 열];: 지정한 열의 값에 따라 행의 순서 정렬* ORDER BY는 행 순서를 변형할 수는 있지만 서버에서 클라이언트로 행 순서를 바꿔 출력하는 것으로 저장장치에 영향을 주지는 않음 ASC/DESCSELECT [원하는 열] FROM [table name] WHERE [조건] ORDER BY [원하는 열] ASC;: 오름차순으로 정렬 의미, ASC의 경우 생략 가능하며 ORDER BY의 기본 정렬 방법 SELECT [원하는 열] FROM [table name] WHERE [조건] ORDER BY [원하는 열] DESC;: 내림차순으로 정렬 대소관계- 작은 것 부터 정렬: ASC..

2. 테이블에서 데이터 검색

04.  Hello World MySQL 설치 및 설정| 패키지 종류: MySQL Enterprise Edition, MySQL Cluster CGE, MySQL Community Server* 학습용으로는 Community Server 권장 mysql 명령 실행- mysql -u [User] -p [pw]- mysql -u [User] -p 입력 후 Enter password: 문구 뒤에 설정한 pw 입력* mysql 설치 당시 지정한 비밀번호를 반드시 기억해야하며 잊어버린 경우 비밀번호 찾기 기능을 지원하지 않음 SELECT데이터베이스의 데이터를 읽어오는 명령어로 행과 열로 구성된 표 형식의 데이터를 출력이때, NULL은 결측치mysql> SELECT * FROM db; * (*)는 애스터리스크로 모..

1. 데이터베이스와 SQL

01. 데이터베이스 데이터베이스- 넓은 의미: 컴퓨터 안에 기록된 모든 것- 일반적으로 통용되는 의미: 특정 데이터를 확인하고 싶을 때 간단하게 찾아낼 수 있도록 정리된 형태의 데이터 주기억장치데이터 베이스 내 데이터는 영구적으로 보존되어야 함휘발성 저장장치: 전원을 끄는 순간 저장한 모든 데이터가 사라짐.비휘발성 저장장치: 하드디스크, 플래시메모리(SSD) DBMS의 사용 목적| 생산성: 시스템 개발 과정 중 생산성 향상을 도모데이터 검색, 추가, 삭제, 갱신 처리와 같은 기본 기능을 DBMS가 제공해 개발에 필요한 작업이 줄어들어 비용적 측면에서 효율적 | 기능성: DBMS가 데이터베이스를 다루는 기능을 제공복수 유저 요청 대응, 대용량 데이터 저장, 고속 검색 , 데이터베이스 관리 기능을 유저가 확..