Coding Story
[ Oracle ] SQL 서브쿼리 SELECT, FROM, WHERE
서브쿼리란? - 하나의 쿼리 문장 내에 포함된 또 하나의 쿼리 문장. - 비교연산자의 오른쪽에 기술해야 하고 반드시 괄호 안에 넣어야 함. - 메인 쿼리가 실행되기 이전에 한 번만 실행됨. SQL의 기본 문법이자 가장 자주쓰이는 SELECT, WHERE, FROM. 서브쿼리를 각각의 어느 위치에서 사용하냐에 따라 나누어진다. 각각의 종류에 따라 살펴보자. SELECT 절 서브쿼리 ( 스칼라 서브쿼리 ) 스칼라 서브쿼리 ( Scalar Subqueries ) 라고 불리며 SELECT 절 안에 서브쿼리가 들어있다. 이 때, 서브쿼리의 결과는 반드시 단일 행이나 SUM, COUNT 등의 집계 함수를 거친 단일 값으로 리턴되어야 한다. 이유는 서브쿼리를 끝마친 값하나를 메인쿼리에서 SELECT ..
[ Oracle ] 오라클 LPAD 와 RPAD
개발을 하다 보면 문자열을 지정된 크기에 맞게 채워야 할 때가 있다. 전화번호를 11자리로 하는데 11자리 미만일경우 0으로 채워라는 경우처럼 말이다. 특정문자열을 지정한 자릿수만큼 내가 지정한 문자로 채우고자 할 때 쓰는 함수가 바로 LPAD 와 RPAD 함수이다. PAD의 영어사전적 의미로는 '덧대다'의 뜻인데 개발에서는 이를 '덧붙이다'나 '채우다'라는 의미로 사용되고 있다. 즉, LEFT PAD ( LPAD ) 는 왼쪽으로부터 채우기, RIGHT PAD ( RPAD ) 는 오른쪽으로부터 채우기인 셈이다. 먼저 문법을 살펴보자. LPAD ( x, n, y ) RPAD ( x, n, y ) 여기서 x 는 LPAD 나 RPAD 를 적용시키고자 하는 문자열이 들어간다. n 은 자릿..
[ Oracle ] 오라클 중복데이터 처리, 중복데이터 한번만
중복 데이터를 처리하는 방법은 다양하다. 중복 데이터를 처리하는 방법에는 어떤것들이 있는지 살펴보자. 만약 아래와 같은 정렬되지 않은 의류 테이블이 존재한다고 가정하자. [ 의류 ] 테이블 위 데이터를 보면 No2 ROW 와 No5 ROW 가 중복되는 데이터임을 알 수 있다. 중복데이터를 제거하고 싶다면 흔히 알고 있는 DISTINCT를 사용하면 된다. SELECT DISTINCT 분류명, 색상명, 가격, 상품번호 FROM 의류 ; 그럼 아래와 같은 결과가 나올것이다. 이처럼 DISTINCT는 데이터가 모두 동일한 ROW가 존재할경우 이를 제거해준다. 그렇다면 중복데이터를 제거하는 것이 아닌 공백이나 널로 처리해 해당데이터가 하나만 보이게하려면 어떻게 해야할까? 필자의 경우 서브쿼리를 ..
[ Android ] 안드로이드 어플 런처 아이콘 변경하기
먼저 여기로 접속한다. 그리고 본인이 원하는 아이콘 선택하고 PNG 클릭. 필자는 체크모양 아이콘을 선택했다. Free Download 클릭 안드로이드 스튜디오에서 File => New => Image Asset 클릭 Name 항목에 런처 아이콘 이름을 입력. 필자는 뒤에 check를 붙였음. Layer Name 항목에 레이어 이름을 입력. 필자는 뒤에 check를 붙였음. Path 항목에 다운로드 받은 이미지의 경로를 입력. Resize 항목에 있는 바를 조정 해 체크 전체 모양이 보이도록 조정 Background Layer 탭을 선택 => Layer Name 수정. 필자는 뒤에 check를 붙였음. Asset Type 을 Color 로 변경하고 원하는 Color 지정하고 Next 클릭. Finish ..
[ Oracle ] 프로시저와 함수의 차이
오라클을 사용하다보면 자주 접하게 되는 프로시저와 함수. 이 둘의 정의와 차이점에 대해 알아보자. 프로시저(Procedure)란? 넓은 의미로는 어떤 업무를 수행하기 위한 절차를 뜻한다. 예를 들어 쇼핑몰에서 신발을 구매하는 프로시저로 표현해본다면 [ Procedure Start ] ① 쇼핑몰 회원 로그인 ② 구매할 신발 선택 ③ 개인정보 및 배송지 선택 ④ 결제 [ Procedure End ] 위 처럼 어떤 프로세스를 절차적으로 기술해 놓은 것을 프로시저라 한다. 프로시저 문법 CREATE OR REPLACE PROCEDURE 프로시저 이름 ( 매개변수명1 [ IN || OUT || INOUT ] 데이터타입, 매개변수명2 [ IN || OUT || INOUT ] 데이터타입 ... ) IS||AS..