금요일에는 DML에 대해 자세히 배워보았다. 초반에 테이블을 만들고 지우느라 Create, Delete기능을 사용하긴 했지만, 제대로 알진 않았기에 이번에 제대로 배워본다. DML Data Manipulation Language : 데이터 조작어 테이블 객체의 데이터에 대해 생성,조회, 수정, 삭제 (CRUD : Create , Read, Update, Delete) 하는 명령어 insert (Create) select (Read) update (Update) delete (Delete) dml명령어 수행시 메모리에서 우선작업하므로 TCL(Transaction Control Language)를 통해서 실제 db에 반영(commit), 작업취소(rollback)하는 과정이 필요하다. * dml언어 사용시에..
유형 분류 결과값에 따른 유형 메인 쿼리 관계에 따른 구분 위치에 따른 구분 1. 단일행 단일컬럼 서브쿼리 (1행 1열) 1. 일반 서브쿼리 서브쿼리의 결과값을 메인쿼리에 통보 1. 스칼라 서브 쿼리 2. 다중행 단일컬럼 서브쿼리 (n행 1열) 3. 단일행 다중컬럼 서브쿼리(1행 n열) 2. 상호연관 서브쿼리 메인쿼리값을 가지고 서브쿼리 처리 후, 메인쿼리에 다시 통보 2. inline - view 4. 다중행 다중컬럼 서브쿼리(n행 m열) 지난시간에 서브쿼리를 분류에 따라 배웠다. 이때, inline - view에 대해 배우지 못했는데, 오늘 배우게 된다. inline view - from절에 사용된 서브쿼리 - view란 실제 테이블에 근거해서 작성된 논리적 가상 테이블을 의미한다. view를 통해 ..
조인문법에는 1. ansi 표준문법 : join, on 키워드 사용 2. oracle 전용문법 : , (콤마 ), where절 사용 두가지 방법이 있다. ansi표준문법의 경우 36, 35일차에 알아보았다. 오라클 표준문법을 ANSI표준문법과 비교해보겠다. EQUI JOIN 1. INNER JOIN 이너조인 ANSI 표준문법은 회색, 오라클 전용 문법은 검정색 창 안에 적었다. 오라클 전용문법은 테이블 순서가 중요하지 않다. select e.emp_name, d.dept_title from employee e inner join department d on e.dept_code = d.dept_id; select e.emp_name, d.dept_title from employee e,department..
JOIN - inner join - outer join 1. left outer join 2. right outer join 3. full outer join - cross join - self join - multiple join SET OPERATOR - union - union all - intersect - minus 이게 오늘까지 배운 내용의 요약이라 할 수 있다. 금요일에 배운 INNER JOIN, OUTER JOIN을 다시 보자. INNER JOIN (이너 조인) - 내부 조인. 두 테이블간의 교집합을 의미한다. - 각 테이블에서 기준컬럼이 null인 행, 상대테이블에서 매칭되는 행이 없는 행 제외. - inner 키워드 생략 가능. (inner) join으로 작성 예시 employee | ..
Group by - 테이블 전체 행을 특정컬럼이 동일한 행끼리 그룹핑 처리 - group by 절이 없다면, 테이블 모든 행이 하나의 그룹으로 처리 - group by에 명시한 컬럼만 select절에 사용될 수 있음. 아닌 컬럼 사용시 오류 발생 - group by 는 null도 그룹으로 처리한다. - 가상컬럼을 가지고도 group by가 가능하다. - group by는 컬럼 순서가 중요하지 않다. - group by에서 여러개의 컬럼을 그룹으로 할 경우, distinct 처리와 같이 두 컬럼의 값이 동일한 행을 그룹핑한다. ex) 부서별로 급여 합계 select dept_code, sum(salary) sum_sal, trunc(avg(salary)) avg_sal from employee group ..
단일행처리 함수 a. 문자처리 함수 length(value) : 글자수를 반환 instr(value, search, [position] , [occurrence]) : value에서 search의 인덱스를 반환 substr(value, position, [length]) : value에서 position부터 length개 잘라서 문자열 반환 lpad(value, len, [padding_str]) : len 에서 value의 길이를 뺀 만큼 padding_str를 왼쪽에 채워서 처리 rpad(value, len, [padding_str]) : len 에서 value의 길이를 뺀만큼 padding_str를 오른쪽에 채워서 처리 length(value) : 글자수를 반환 select emp_name, len..
DQL Data Query Language : 테이블의 데이터를 검색(추출)하기 위해 사용하는 sql DML의 하위 그룹으료 분류 데이터 조회결과를 Result Set(결과 집합)이라고 함. 조회시 0행 이상의 결과집합을 리턴받음. select (필수) 5. 조회할 컬럼 from (필수) 1. 조회할 테이블 where 2. 조건절 (true - 결과집합에 포함, false - 결과집합에 제외) group by 3. 행을 특정컬럼 기준으로 그룹핑 having 4. 그룹핑된 결과에 대한 조건절 order by 6. 행간 정렬 숫자는 실제 처리 순서이고, 이 순서대로 코드를 작성하는 것을 추천한다. SELECT - 실제 결과집합(result set)의 컬럼을 제한 - 존재하지 않는 컬럼도 조회함 - 가상컬럼 ..
드디어 본격적으로 오라클에 대해 배우게 되었다. 0. DATA / DATABASE 란 Data - 관찰의 결과로 나타난 정량적 혹은 정성적인 실제 값을 의미 Database - 한 조직에 필요한 정보를 여러 응용 시스템에서 공용할 수 있도록 논리적으로 연관된 데이터를 모으고, 중복되는 데이터를 최소화 하여 구조적으로 통합, 저장해놓은 것 Database의 특징 4가지 1. 실시간 접근성 - 사용자가 데이터를 요청하면 실시간으로 결과 서비스함 2. 계속적인 변화 - 데이터값은 시간에 따라 항상 바뀜 3. 동시 공유 - DB는 서로다른 업무, 또는 여러사용자에게 동시공유됨 4. 내용에 따른 참조 - DB에 저장된 데이터는 DB의 물리적 위치가 아니라 DB값에 따라 참조됨 DBMS의 특징 CRUD 의 기능을 ..
원래 Ctrl+클릭으로 다음 요소로 진입하는건 mybatipse라는 이클립스 프로그램을 통해 가능하다. Help - EclipseMarketplace 에서 mybatipse 검색. 근데 이게 깔려있는데도 불구하고 전자정부프레임워크 3.8에서는 안되는 경우가 있다. 이럴때는 Help - Install New Software - add 에서 http://maven.egovframe.kr:8080/update_3.8_DBIO_patch/ 를 입력해서 패치하자 eGovFramework DBO 3.8.0.201909201457 을 선택하면된다 (어짜피 이거밖에안뜸) 이후에는 xml mapper가 잘 나오는것을 확인할 수 있다.
클라이언트에서 서버를 찾을때, 우리가 아는 주소 이름 naver.com으로는 찾을 수가 없다. naver.com은 주소값을 찾아오기 위한 문자열일 뿐이고, 실제 주소값은 모두 숫자로 되어있다. 실제로는 이렇게 통신을 하는데, DNS서버가 존재해서 naver.com의 IP주소 (예를들어 7.7.7.7) 를 주고받고, 이를 통해서 IP주소를 알게 된다. 하지만 이렇게 하면 컴퓨터만 찾게 된다. 컴퓨터 내에서 프로그램을 식별하려면 Port가 필요한데, 이 Port값은 찾지 못하는 것이다. =즉 , 프로그램을 실행하기 위해서는 IP주소와 Port번호가 필요하다. cmd창에서 ipconfig를 쳐보면, 나의 IPv4주소를 알 수 있다. InetAddress - 특정 도메인의 ip주소에 대한 정보를 관리하는 클래스..