분류 전체보기(361)
-
5. Bags and Extended Relational Algebra
Relational Operations on Bags Set: 중복된 튜플을 제거한 릴레이션 Bag(Multiset): 중복된 튜플을 포함할 수 있는 릴레이션 Bag을 사용하는 이유 효율성(속도) Set으로 합집합 연산을 하게 되면 두 릴레이션을 합한 후 일일이 중복을 찾아내 제거하는 연산을 하게 됨 Bag으로 합집합 연산을 하게 되면 두 릴레이션을 합한 후 연산이 종료되므로 속도가 훨씬 빠름 Bag 연산으로 두 릴레이션을 합집합하면 중복되는 튜플이 사라지지 않고 합해지므로 결과가 달라질 수 있음(합계, 평균, 카운트 등) 프로젝션 연산은 중복된 컬럼을 제거하지만 Bag연산으로 하면 중복을 포함함 즉 각 튜플마다 독립적으로 수행됨(셀렉션도 마찬가지) Extended Operators to Relation..
2021.05.02 -
4. Relational Algebra
데이터베이스를 사용하는 주된 이유는 쿼리를 사용하여 데이터를 효율적으로 처리하기 위해서다. Relational Algebra Relational model은 데이터에 대한 작업이 표준화되어있고, 그 작업을 수학적으로 나타낼 수 있다. Relational algebra - 가장 많이 사용됨 Relational calculus Datalog ODL은 데이터에 대한 여러 작업을 수행할 수있는 메소드를 사용하는 방법이다. 아직 수학적으로 표현할 수 없다 E/R model은 데이텅 조작에 대한 구체적인 방법을 포함하지 않는다 What is Algebra? Algebra = operators + atomic operands Arithmetic algebra Atomic operands: x나 y같은 변수 또는 37..
2021.05.02 -
3. Defining a Schema in SQL
Character StringsCHAR(n) = CHARACTER(n)크기를 지정하지 않을 시 1로 지정됨VARCHAR(n) = CHAR VARYING(n) = CHARACTER VARYING(n)문자열 입력 시에는 Single Quote 사용('') Double Quote 불가CHAR로 선언 후에 공간을 모두 사용하지 않으면 공백을 추가a char(7) = 'hello' → 'hello 'VARCHAR는 사용하지 않은 공간은 무시함b varchar(7) = 'world' → 'world'Bit StringsBIT(n), BIT VARYING(n)리터럴(아래는 PostgreSQL 한정)2진수 - B'0101'16진수 - X'FF0'BooleanBOOLEAN: { TRUE, FALSE, UNKNOWN }D..
2021.05.02 -
2. Relational Data Model
데이터 모델 데이터나 정보를 설명하는 표현 방법 일반적으로 세 부분으로 구성됨 데이터 구조 데이터 운영 데이터 제약 조건 중요한 데이터 모델 관계형 모델(The Relational Model) XML을 포함하는 부분구조화된 데이터 모델 다른 데이터 모델 객체지향 데이터 모델 객체-관계형 모델 계층(트리) 모델 네트워크 모델 관계형 모델 릴레이션(테이블) 속성(컬럼) title, year, length, genre 스키마 테이블의 구조 Movies(title, year, length, genre) 튜플(행) (Gone With the Wind, 1939, 231, drama) 도메인 Movies(title: string, year: integer, length: integer, genre: string) ..
2021.05.02 -
3-3. 프로세스의 연산
1. 프로세스의 구조코드 영역프로그램의 본문이 기술된 곳으로 텍스트 영역이라고도 한다. 프로그래머가 작성한 프로그램은 코드 영역에 탑재되며 탑재된 코드는 읽기 전용으로 처리된다.데이터 영역코드가 실행되면서 사용하는 변수나 파일 등의 각종 데이터를 모아놓은 영역이다. 기본적으로 읽기와 쓰기가 가능하며, 상수는 읽기 전용이다.스택 영역운영체제가 프로세스를 실행하기 위해 부수적으로 필요한 데이터를 모아놓은 곳이다. 스택 영역은 운영체제가 사용자의 프로세스를 작동하기 위해 유지하는 영역이므로 사용자에게는 보이지 않는다.2. 프로세스의 생성과 복사프로세스는 프로그램을 실행할 때 새로 생성된다. 사용자가 프로그램을 실행하면 운영체제는 프로그램을 메모리로 가져와 코드 영역에 넣고 PCB를 생성한다. 그리고 메모리에 ..
2021.05.02 -
3-2. PCB와 문맥 교환
1. PCBPCB는 프로세스를 실행하는 데 필요한 중요한 정보를 보관하는 자료구조로, TCB(Task Control Block)이라고도 한다. 모든 프로세스는 PCB를 가지며, PCB는 프로세스 생성 시 만들어져서 프로세스가 실행을 완료하면 폐기된다.구성포인터: PCB의 첫 번째 블록에 저장된다. 준비 상태나 대기 상태는 큐로 운영되는데, PCB를 연결하여 준비 상태나 대기 상태의 큐를 구현할 때 포인터를 사용한다.프로세스 상태: 생성, 준비, 실행, 대기, 보류 준비, 보류 대기 등이 있다. 즉 프로세스가 현재 어떤 상태에 있는지 나타내며, PCB의 두 번째 블록에 저장된다.프로세스 구분자: 운영체제 내에 있는 여러 프로세스를 구별하기 위한 구분자를 저장한다.프로그램 카운터: 다음에 실행될 명령어의 위..
2021.05.02