[정처산기] 필기준비 : SQL활용(1) [기본 SQL 작성하기]

2022. 7. 9. 17:02·◈ 자격증 공부/정보처리산업기사🔅
728x90

 

[정처산기] 필기준비 : 화면 구현(2) [UI 구현하기]

[정처산기] 필기준비 : 화면 구현(1) [UI 설계 확인하기] [정처산기] 필기준비 : 프로그래밍 언어 활용(3) [스크립트 언어 활용하기] [정처산기] 필기준비 : 프로그래밍 언어 활용(2) [객체지향 프로그

yermi.tistory.com


1. 기본 SQL 작성하기

1-1. 테이블의 데이터 사전 조회

1) 데이터 사전

(1) 데이터 사전 개념

  • 사용자 데이터를 제외한 모든 정보(DBMS가 관리하는 데이터)가 있는 곳
  • 데이터 사전의 내용을 변경하는 권한은 시스템 사용자(데이터베이스 관리자: DBA)가 가짐
  • 일반 사용자에게는 단순 조회만 가능한 읽기 전용 테이블 형태가 제공

(2) 데이터 사전 내용

  • 사용자 정보(ID, 비밀번호 및 권한 등)
  • 데이터베이스 객체(테이블, 인덱스, 뷰 등)
  • 무결성 제약 상태
  • 함수, 프로시저 및 트리거 정보 등

 

2) 테이블에 대한 기본적인 데이터 사전 조회

(1) 오라클에서 테이블의 데이터 사전 조회

오라클 사용자는 뷰(View)로 데이터 사전에 접근할 수 있다.
→ 접근 권한 : DBA_ > ALL_ > USER_

 

오라클 데이터 사전 영역 / 참고 : NCS 학습모듈 교재

 

(2) MY-SQL에서 테이블의 데이터 사전 검색

MY-SQL에서 데이터 사전은 테이블 형태로 구성되어 있다.
→ 테이블의 내용을 검색하기 위 해서는 해당 테이블의 위치와 이름을 정확히 알고 있어야 한다.

 

use Information_schema; -- 이동
show tables; -- 테이블 목록 보기

 

MY-SQL 데이터 사전 목록 조회 / 참고 : NCS 학습모듈 교재
MY-SQL 테이블의 데이터 사전 목록 / 참고 : NCS 학습모듈 교재


1-2. 기본적인 SQL 작성

1) 데이터 정의(DDL문)

(1) DDL 개념

DDL(Data Definition Language)
→ ‘데이터를 정의하는 언어', ‘데이터를 담을 그릇을 생성하는 언어'

 

DDL 대상 / 참고 : NCS 학습모듈 교재

 

(2) DDL 유형

DDL 명령어 / 참고 : NCS 학습모듈 교재

 

(3) DDL 작성

① 테이블 생성

테이블 생성 SQL문 / 참고 : NCS 학습모듈 교재

 

② 테이블 변경

ALTER 이용한 테이블 변경 SQL문 / 참고 : NCS 학습모듈 교재

 

③ 테이블 삭제, 절단, 이름 변경

테이블 삭제 및 이름 변경 방법 / 참고 : NCS 학습모듈 교재

 

④ 제약 조건 적용

테이블 생성에 사용되는 제약 조건 / 참고 : NCS 학습모듈 교재

 

2) 다중 테이블 조회(DML문)

다중 테이블 검색 방법 / 참고 : NCS 학습모듈 교재

 

(1) 조인(JOIN)

① 조인 개념

조인은 두 테이블의 공통값을 이용하여 칼럼을 조합하는 수단
→ 보통 PK와 FK값을 결합하여 사용하는 것이 일반적

 

조인 개념도 / 참고 : NCS 학습모듈 교재

 

② 조인 유형

조인 유형(대분류) / 참고 : NCS 학습모듈 교재
조인 유형(세분류) / 참고 : NCS 학습모듈 교재

 

(2) 서브쿼리(Sub-Query)

① 서브쿼리 개념

SQL문 안에 포함된 또 다른 SQL문

서브쿼리 개념도 / 참고 : NCS 학습모듈 교재

 

② 서브쿼리 유형

서브쿼리 유형 1 / 참고 : NCS 학습모듈 교재
서브쿼리 유형 2 / 참고 : NCS 학습모듈 교재

 

(3) 집합 연산자

① 집합 연산자 개념

2개 이상의 쿼리를 연결하여 하나로 통합해 주는 역할

 

② 집합 연산자 유형

집합 연산자 유형 / 참고 : NCS 학습모듈 교재

 

3) 데이터 제어(DCL 문)

(1) DCL 개념

데이터베이스에서 데이터 외의 오브젝트를 조작하려고 하는 경우에 DCL 명령을 사용
→ DCL은 Data Control Language라는 약자

 

DCL 조작 대상 / 참고 : NCS 학습모듈 교재

 

트랜잭션 제어를 위한 명령어 TCL(Transaction Control Language)라는 용어도 있으나, 제어 기능이라는 공통점으로 TCL은 DCL의 일부로 분류하기도 한다.

 

DCL 명령어 / 참고 : NCS 학습모듈 교재

 

(2) DCL 작성

① 사용자 권한 부여

권한 부여 명령어 문법 / 참고 : NCS 학습모듈 교재

 

② 사용자 권한 회수

권한 회수 명령어 문법 / 참고 : NCS 학습모듈 교재

 

(3) TCL 활용

① 트랜잭션 개념

트랜잭션은 ‘일을 처리하는 단위’를 의미

 

트랜잭션의 특징 / 참고 : NCS 학습모듈 교재

 

② 트랜잭션 제어

TCL 명령어 / 참고 : NCS 학습모듈 교재
트랜잭션 시나리오 / 참고 : NCS 학습모듈 교재
트랜잭션 ROLLBACK 경우 / 참고 : NCS 학습모듈 교재

 

(4) 권한 유형

권한 유형 / 참고 : NCS 학습모듈 교재

 

참고자료 : https://www.ncs.go.kr


 


728x90
'◈ 자격증 공부/정보처리산업기사🔅' 카테고리의 다른 글
  • [정처산기] 필기준비 : 데이터 입출력 구현(1) [논리 데이터저장소 확인하기]
  • [정처산기] 필기준비 : SQL활용(2) [고급 SQL 작성하기]
  • [정처산기] 필기준비 : 화면 구현(2) [UI 구현하기]
  • [정처산기] 필기준비 : 화면 구현(1) [UI 설계 확인하기]
예르미(yermi)
예르미(yermi)
끊임없이 제 자신을 계발하는 개발자입니다👨🏻‍💻
  • 예르미(yermi)
    예르미의 코딩노트
    예르미(yermi)
  • 전체
    오늘
    어제
    • 분류 전체보기 (939) N
      • ◎ Java (133)
        • Java☕ (93)
        • JSP📋 (26)
        • Applet🧳 (6)
        • Interview👨🏻‍🏫 (8)
      • ◎ JavaScript (48)
        • JavaScript🦎 (25)
        • jQuery🌊 (8)
        • React🌐 (2)
        • Vue.js🔰 (6)
        • Node.js🫒 (3)
        • Google App Script🐑 (4)
      • ◎ HTML5+CSS3 (17)
        • HTML5📝 (8)
        • CSS3🎨 (9)
      • ──────────── (0)
      • ▣ Framework (67)
        • Spring🍃 (36)
        • Spring Boot🍀 (12)
        • Bootstrap💜 (3)
        • Selenium🌕 (6)
        • MyBatis🐣 (10)
      • ▣ Tools (47)
        • API🎯 (18)
        • Library🎲 (15)
        • JitPack🚀 (3)
        • Jenkins👨🏻 (7)
        • Thymeleaf🌿 (4)
      • ▣ Server (30)
        • Apache Tomcat🐱 (14)
        • Apache HTTP Server🛡️ (1)
        • Nginx🧶 (7)
        • OracleXE💿 (4)
        • VisualSVN📡 (4)
      • ▣ OS : 운영체제 (18)
        • cmd : 명령프롬프트💻 (10)
        • Linux🐧 (8)
      • ▣ SQL : Database (56)
        • Oracle SQL🏮 (26)
        • PL SQL💾 (9)
        • MySQL🐬 (6)
        • MariaDB🦦 (6)
        • H2 Database🔠 (3)
        • SQL 실전문제🐌 (6)
      • ────────── (0)
      • ◈ Human Project (86)
        • Mini : Library Service📚 (15)
        • 화면 설계 [HTML]🐯 (10)
        • 서버 프로그램 구현🦁 (15)
        • Team : 여수어때🛫 (19)
        • Custom : Student🏫 (9)
        • Custom : Board📖 (18)
      • ◈ Yermi Project (40)
        • 조사모아(Josa-moa)📬 (5)
        • Riddle-Game🧩 (6)
        • 맛있을 지도🍚 (2)
        • 어디 가! 박대리!🙋🏻‍♂️ (5)
        • 조크베어🐻‍❄️ (4)
        • Looks Like Thirty🦉 (2)
        • Toy Project💎 (12)
        • 오픈소스 파헤치기🪐 (4)
      • ◈ Refactoring (15)
        • Mini : Library Service📚 (8)
        • 서버 프로그램 구현🦁 (1)
        • Team : 여수어때🛫 (0)
        • 쿼리 튜닝일지🔧 (6)
      • ◈ Coding Test (91) N
        • 백준(BOJ)👨🏻‍💻 (71) N
        • 프로그래머스😎 (2)
        • 코드트리🌳 (7)
        • 알고리즘(Algorithm)🎡 (11) N
      • ◈ Study (102)
        • 기초튼튼 개발지식🥔 (25)
        • HTTP 웹 지식💡 (4)
        • 클린코드(Clean Code)🩺 (1)
        • 디자인패턴(GoF)🥞 (12)
        • 다이어그램(Diagram)📈 (4)
        • 파이썬(Python)🐍 (16)
        • 에러노트(Error Note)🧱 (34)
        • 웹 보안(Web Security)🔐 (6)
      • ◈ 공부모임 (39)
        • 혼공학습단⏰ (18)
        • 코드트리 챌린지👊🏻 (2)
        • 개발도서 100독👟 (8)
        • 나는 리뷰어다🌾 (11)
      • ◈ 자격증 공부 (37)
        • 정보처리기사🔱 (16)
        • 정보처리산업기사🔅 (9)
        • 컴퓨터활용능력 1급📼 (12)
      • ─────────── (0)
      • ◐ 기타 (113)
        • 알아두면 좋은 팁(tip)✨ (46)
        • 개발자의 일상🎈 (44)
        • 개발도서 서평🔍 (10)
        • 개발관련 세미나🎤 (2)
        • 블로그 꾸미기🎀 (9)
        • 사도신경 프로젝트🎚️ (2)
  • 인기 글

  • 최근 댓글

  • 태그

    일상
    백준 티어
    spring
    jsp
    Java
    SQL
    백준
    코딩
    꿀팁
    프로그래밍
    Oracle
    Error Note
    코딩 테스트
    CSS
    Project
    Database
    javascript
    BOJ
    html
    자바스크립트
  • 250x250
  • hELLO· Designed By정상우.v4.10.3
예르미(yermi)
[정처산기] 필기준비 : SQL활용(1) [기본 SQL 작성하기]
상단으로

티스토리툴바