Category Archives: development

Maximum URL Length

HTTP Get방식으로 호출시 URL의 길이제한이 있다는 것은 이전부터 알고 있었는데, 어느 순간부터 인지 조작된 기억을 머릿속에 넣고 다니고 있었다…;;;;   분명 2년전 프로젝트에서 url 길이 제한과 관련하여 검색했던 적이 있었는데…..  그 사이 한두살 나이를 더 먹어서 그런지 기억이 가물해지며……….아울러 내 기억속의 URL 최대길이도….점점 줄어들어 256byte 내외로 해야한다는 것으로 기억하고 있는 …….;;;;

방금 작업 중에 URL이 너무 길이서 확인을 해보니 280byte….
내 기억속에 남아있는 길이보다 기네….;;;

잠시 멘붕이 올뻔 했으나 검색질을 해보니……..RFC 규격에서 딱히 길이를 제한하고 있지는 않은듯….. (http://tools.ietf.org/html/rfc2616#section-3.2.1)
다만 오래된 브라우저를 위해서 255byte 내외를 사용하라는 약간의 노트정도가 있긴하지만, 대상 서비스 자체가 그런 브라우저는 포함하지 않기 때문에 무시해도 될듯….

검색질을 더 하다보니 MS IE의 경우에는….2,083byte라는….문서가 있는데…
http://support.microsoft.com/default.aspx?scid=kb;EN-US;q208427
좀 더 검색질을 하다보니…나같은 사람을 위해 같은 문서가 한글로 번역도 되어있는…..
http://support.microsoft.com/kb/208427

stackoverflow에서는 다음과 같은 내용도 있으나….
http://stackoverflow.com/questions/3721034/how-long-an-url-can-internet-explorer-9-take
나는 영어랑 안친하니까…..
그리고 이미 내가 필요한 정보는 모두 습득했으니 패스…

어쨌든 내 머릿속에 존재하던 URL 최대 길이 256byte는…………..
언제부터 조작된 상태였던 걸까??????

그 조작된 기억으로 주변 지인들에게 사기친 셈이 되버렸지만……………
다시 제대로 된 정보를 전달하는건 일부러 하지는 말아야지..ㅎㅎㅎ

기회가 되면 하게 되거나…….아니면 알아서 찾겠지 뭐…;;;;;
여길 들어와보는 사람이면 알아서 …..나의 구라를 알아차릴테고………

인생 뭐 그런거지…..

oracle sum() over()

출처 : http://blog.naver.com/hjc426/130037056133

SUM() OVER() ORACLE 내장 함수
SCOTT 계정의 EMP TABLE에서 테스트를 진행한다
다음의 QUERY 을 보면 이해가 쉽다.
———————————————————————————————-
SELECT ENAME,
DEPTNO,
SAL,
SUM(SAL) OVER (PARTITION BY DEPTNO)                         “부서별 급여합계”,
SUM(SAL) OVER (PARTITION BY DEPTNO ORDER BY SAL)    “부서별 급여오름차순 누적합”,
SUM(SAL) OVER (ORDER BY DEPTNO, SAL)                       “부서별 급여오름차순 누적합”,
SUM(SAL) OVER ()                                                        “전체 급여합”
FROM EMP;
———————————————————————————————-
위 QUERY  의 결과는 다음과 같다.

원래 SUM 함수는 GROUP 함수다.
따라서 위와 같은 부분에서 ENAME, DEPTNO, SAL 로 GROUP BY 을 해줘야 한다.
하지만 SUM() OVER()를 사용할 때는 GROUP BY 가 필요 없다

1.  SUM(COLUMN1) OVER(PARTITION BY COLUMN2) —>
이는 특정 컬럼2로 그룹핑 한 컬럼1의 SUM 값을 보여준다
위에서처럼 부서별 급여합이 된다. 10부서, 20부서 등의 급여 합을 보여준다

2. SUM(COLUMN1) OVER(PARTITION BY COLUMN2 ORDER BY COLUMN1) —>
이는 위에서보는 것처럼 컬럼2로 그룹핑한 데이터를 컬럼1로 오름차순 정렬을 하면서 SUM을 구한다.
이는 위의 예에서 보는 부서별 급여의 누적된 합을 구할 때 쓸 수 있다.
여기서 위와 같은 부분은 PARTITION BY 않하고 정렬을 통해서도 구현이 가능하다SUM(COLUMN1) OVER(ORDER BY COLUMN1, COLUMN1)
다음처럼 쓰면 PARTITION 한 것과 같은 결과를 얻을 수 있다.

3. SUM(COLUMN) OVER() —>
마지막으로 이는 컬럼의 전체 합을 리턴하게 된다..
GROUP BY 는 쓰는데 제약이 존재할 때가 있다.
난 개인적으로 그런 GROUP BY 를 싫어한다.
하지만 개발시에 그룹별로 보여줘야 할 부분은 너무 많다.
법인별, 부서별 등등의 어떤 내역 조회의 경우….이는 불가피할 것이다.

이런 TIP도 추가로 알면 개발할 때 유용할 것이다.