IT, 프로그래밍
-
[PL/SQL] 커서 (Cursor)IT, 프로그래밍/Database (Oracle) 2019. 1. 17. 16:10
커서란, SQL문을 처리한 결과 집합을 가리키는 일종의 포인터이다. (C에서 나오는 포인터 개념과 유사하다)이 결과 집합은 오라클 서버 프로세스 내부의 Private SQL Area라는 메모리 영역에 저장되는데,여기서 유의해야 할 점은 커서는 클라이언트 측 프로세스에서 가리키고 있다는 점이다.Private SQL Area는 특정 쿼리에 대한 결과를 저장하면서 캐싱 하는 역할을 하는데,한 세션 안에서 같은 쿼리를 반복적으로 호출한다면, 저장되어 있는 결과 집합을 반환하면서 자원 낭비를 최소화한다. >> 더 자세한 아키텍쳐를 알고 싶으면 여기를 참고
-
[PL/SQL] 트랜잭션 (Transaction)IT, 프로그래밍/Database (Oracle) 2019. 1. 17. 11:00
트랜잭션(Transaction)이란, 일관성 있는 상호작용을 위한 단위이다. 데이터베이스 시스템은 ACID (Atomicity, Consistency, Isolation, Durability)를 보장하기 위해 트랜잭션을 논리적 작업단위로 사용한다. 트랜잭션을 통해 데이터베이스는 항상 일관성 있는 상태를 유지해야 한다. 비유를 하자면, 돈을 입금하는 도중에 오류가 발생하여 거래가 취소되면 많은 문제가 생길 수 있다. 이를 위해 은행 거래에서는 완전히 거래가 끝났을시에 거래 정보를 확정하고, 오류가 발생하면 거래를 시작하기 전의 상태로 되돌린다. PL/SQL상에서 사용할 수 있는 트랜잭션은 아래와 같다. 1. COMMIT 데이터베이스 연산이 정확하게 종료되어 변경내역을 실제 데이터베이스에 반영한다.만약 DB..
-
[PL/SQL] 예외처리IT, 프로그래밍/Database (Oracle) 2019. 1. 17. 08:30
간단하게 설명하자면, 컴파일 에러는 컴파일러가 컴파일시에 확인하여 나오는 오타같은 에러고,예외는 컴파일이 되어 프로그램이 작동되는 중이지만, 예기치 못한 null값의 입력등으로 생기는 예외이다.시스템 예외는 오라클이 미리 이런 예외 상황에 대해 미리 정의해 놓은 예외이며, 오라클 시스템에서 자동으로 잡아준다.사용자 정의 예외는 예상되는 특정 예외 상황에 대해 개발자가 직접 정의한 예외이다 EXCEPTION WHEN 예외명1 THEN 예외처리 구문1WHEN 예외명2 THEN 예외처리 구문2...WHEN OTHERS THEN 예외처리 구문n; 자바 프로그래밍을 해 본 사람이라면, try-catch 문과 유사하다는 점을 떠올릴 수 있을 것이다. 1234567891011 try { FileInputStream ..
-
[PL/SQL] 함수와 프로시저IT, 프로그래밍/Database (Oracle) 2019. 1. 16. 13:58
PL/SQL의 대표적인 부 프로그램에는 함수(Function)과 프로시져(Procedure)가 있다. 함수(Function) 함수 생성 CREATE OR REPLACE FUNCTION 함수 이름 (매개변수1, 매개변수2....)RETURN 데이터 타입;IS[AS]변수, 상수 선언..BEGIN실행부 RETURN 반환값[EXCEPTION 예외처리부]END [함수 이름]; 함수는 기본적으로 SQL문 안에서 사용해야 한다.오라클에서 기본적으로 제공해주는 함수(concat 이라던가하는..)는 Built-in 함수라고 부른다. 보통 PL/SQL에서 함수란 사용자가 직접 정의한 함수를 말한다. 1234567891011CREATE OR REPLACE FUNCTION fu_sum_gugu( vn_row NUMBER )R..
-
[PL/SQL] 기초 문법IT, 프로그래밍/Database (Oracle) 2019. 1. 16. 09:18
반복문 LOOP, WHILE, FOR 1. LOOP LOOP처리문EXIT [WHEN 조건];END LOOP; 12345678910111213141516DECLARE vs_gugu_line number := 1; vs_gugu_col number :=1;BEGIN LOOP DBMS_OUTPUT.PUT_LINE( vs_gugu_line || '단 입니다.'); vs_gugu_col := 1; LOOP DBMS_OUTPUT.PUT_LINE(vs_gugu_line || ' * ' || vs_gugu_col || ' = ' || (vs_gugu_line * vs_gugu_col)); vs_gugu_col := vs_gugu_col + 1; EXIT WHEN vs_gugu_col > 9; END LOOP; vs_g..
-
[PL/SQL] PL/SQL 기초IT, 프로그래밍/Database (Oracle) 2019. 1. 15. 23:12
PL/SQL (Oracle's Procedural Language extension to SQL) = 오라클에서 SQL을 확장하여 사용하는 프로그래밍 언어. 이름과 같이 절차적 프로그래밍 언어이다. PL/SQL을 왜 사용할까? 1. 대용량 데이터를 연산해야 할 때, WAS등의 서버로 전송해서 처리하려면 네트워크에 부하가 많이 걸릴 수 있다. 이때 프로시져나 함수를 사용하여 데이터를 연산하고 가공한 후에, 최종 결과만 서버에 전송하면 부담을 많이 줄일 수 있다. 2. 로직을 수정하기 위해 서버를 셧다운 시키지 않아도 된다. 서버에서는 단순히 DB에 프로시저를 호출하여 사용하면 된다. 3. 쿼리문을 직접 노출하지 않는 만큼, SQL injection의 위험성이 줄어든다. 4. 블록 단위로 유연하게 사용할 수..
-
[디자인패턴] 컴포지트 패턴 (Composite Pattern)IT, 프로그래밍/Design Patterns 2019. 1. 9. 21:41
컴포지트 패턴 (Composite Pattern) = 객체들을 트리 구조로 구성하여 부분과 전체를 나타내는 계층 구조로 표현하는 것. 클리이언트에서 개밸 객체와 다른 객체들로 구성된 복합 객체(Composite)를 똑같은 방법으로 다룰 수 있음. Component (Interface) : 복합 객체내에 들어있는 모든 객체들에 대한 인터페이스를 제공합니다. 복합노드, 리프노드에 대한 메소드를 정의함. Leaf : 그 안에 들어있는 원소에 대한 행동을 정의.Composite (=복합객체) : 자식이 있는 구성요소의 행동을 정의하고 자식 구성요소를 저장하는 역할을 맡음. Client : Component 인터페이스를 사용해 복합 객체 내의 객체들을 조작할 수 있음. Composite = Composite + ..
-
[Java] javap를 사용하여 바이트코드를 확인해보자IT, 프로그래밍/Java 2019. 1. 9. 15:11
가끔 코드를 작성하다 보면 실제 동작되는 바이트 코드를 확인하고 싶을 때가 있습니다.이럴 때 JDK에 내장되어 있는 javap 라는 역어셈블러를 사용하면 됩니다. 1. cmd를 켜서 workspace에 있는 프로젝트 파일 안의 bin 폴더로 이동합니다. ( cd C:\user\kim\workspace\yourProejct\bin )2. javap -c 패키지명.클래스파일명 으로 명령을 수행합니다. 기타 옵션 -? 도움말을 출력 -l 클래스 내 모든 라인 번호와 지역변수 테이블을 출력합니다 -public 클래스 내 public 접근 지정자로 선언된 클래스와 멤버를 출력합니다. -protected 클래스 내 protected 접근 지정자로 선언된 클래스와 멤버를 출력합니다. -private 클래스 내 pri..