728x90

DB는내운명 | 기타 | 2013-10-17 18:11:52


안녕하세요 DB2 에 대해 질문이 있습니다. 

인다우트 트랜젝션, XA 트랜젝션에 대한 개념이 궁금합니다.

한번쯤을 들어는 봤는데. 정확히 정의를 내리기에는 모르는것이 많습니다.

고수님의 도움이 필요합니다.

감사합니다.




pajama 2013-10-18 01:10:24
WAS를 생각하시면 좋을것 같습니다.
클라이언트에서 요청한 트랜잭션이 여러개의 리소스(데이터베이스)에 접속해서 처리해야한다고 했을때
어플리케이션 서버가 각 리소스에 대한 트랜잭션을 관리하고 정상적으로 커밋(commit) 되었을 때 클라이언트에 트랜잭션 처리결과를 알리게 됩니다. 이러한 방식을 XA, 글로벌 트랜잭션이라고도 합니다.

이러한 처리중에 개별 리소스중 커밋이 되지 않은 경우 indoubt transaction으로 남기도 합니다
그럴때는 커밋/롤백을 수동으로 해줄수도 있습니다. 처리하지 않으면 트랜잭션이 종료되지 않아 테이블 락이나 트랜잭션 로그 풀등의 문제가 발생할 수 있습니다.


728x90
728x90

스캇님 | 쿼리 | 2013-10-17 10:40:49


안녕하세요.
아래와 같이 하고 싶은데
오라클은  wm_concat 함수가 있는데 DB2 없나요?
wm_concat 함수 사용 안하고 하는 방법도 있나요?

원래 데이터

학과     이름

경영    홍
경영    김
경영    최
회계    이
수학    박


결과

학과  이름

경영    홍,김,최
회계    이
수학    박




pajama 2013-10-17 10:59:34
wm_concat이라는 함수는 제공을 하지않고, listagg라는 함수를 사용하면 됩니다.

$ db2 "select a,listagg(b,',') from test group by a"

A 2
---------- ------------
경영 홍,김,최
수학 박
회계 이

http://pic.dhe.ibm.com/infocenter/db2luw/v10r5/topic/com.ibm.db2.luw.sql.ref.doc/doc/r0058709.html

스캇 2013-10-17 13:06:19
DB2 AS400 UDB 7.1 은 지원 안 하나요? 안되는데요..

pajama 2013-10-18 02:48:24
말씀하신 버전에서는 함수지원을 하지않습니다. recursive query나 사용자 정의 함수, 또는 어플리케이션으로 처리해야합니다



728x90
728x90

LOUPOS님 | 2013-10-16 19:23:15


안녕하세요

대량의 REORG 작업을 수행하던 도중 아래와 같은 에러가 발생하였습니다.
내용상으로는 연속된 REORG 작업이 많은 LOG를 생성한것 같습니다.
이로인하여 추가적인 작업이 모두 불가능한 상태 입니다.

 
때문에 아래 로그를 비워주는 명령어를 수행하였으나 실제로 파일이 삭제되거나
파일 사이즈가 비워지거나 하는등의 변화가 없습니다.

 
또한 [Log retain] 값이 NO로 설정된 것으로 보아 순환 로깅을 사용중일 텐데 왜 이런 에러가 발생한지 의문입니다.

 
처리 방법을 문의 드립니다.

(로그파일 공간 확장은 이미 어느정도 올려놓은 상태입니다. 순환 로깅만 제대로 되면 될거 같은데... 이부분이 궁금합니다.)

 
======아래======

 

ERROR [57011] [IBM][DB2/AIX64] SQL0964C  The transaction log for the database is full.


 

 
total 92161472
drwxr-xr-x    2 db2inst  db2igrp        4096 10¿ù 16ÀÏ 18:51 .
drwxr-xr-x   31 root     system         4096 10¿ù 15ÀÏ 11:49 ..
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 15:41 S0014425.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 15:41 S0014426.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 15:43 S0014427.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 15:45 S0014428.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 15:46 S0014429.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 15:48 S0014430.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 15:51 S0014431.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 15:54 S0014432.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 15:57 S0014433.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 16:00 S0014434.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 16:10 S0014435.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 16:20 S0014436.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 16:24 S0014437.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 16:28 S0014438.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 16:37 S0014439.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 16:44 S0014440.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 16:52 S0014441.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 16:57 S0014442.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 16:59 S0014443.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 17:00 S0014444.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 17:01 S0014445.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 17:03 S0014446.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 17:04 S0014447.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 17:05 S0014448.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 17:06 S0014449.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 17:07 S0014450.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 17:08 S0014451.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 17:09 S0014452.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 17:10 S0014453.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 17:11 S0014454.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 17:12 S0014455.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 17:13 S0014456.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 17:14 S0014457.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 17:15 S0014458.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 17:16 S0014459.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 17:17 S0014460.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 17:18 S0014461.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 17:19 S0014462.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 17:21 S0014463.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 17:23 S0014464.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 17:24 S0014465.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 17:25 S0014466.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 17:26 S0014467.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 17:27 S0014468.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 17:29 S0014469.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 17:31 S0014470.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 17:33 S0014471.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 17:36 S0014472.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 17:38 S0014473.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 17:40 S0014474.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 17:42 S0014475.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 17:44 S0014476.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 17:46 S0014477.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 17:49 S0014478.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 17:54 S0014479.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 17:55 S0014480.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 17:57 S0014481.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 17:59 S0014482.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 18:02 S0014483.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 18:04 S0014484.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 18:06 S0014485.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 18:07 S0014486.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 18:09 S0014487.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 18:11 S0014488.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 18:14 S0014489.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 18:16 S0014490.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 18:16 S0014491.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 18:18 S0014492.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 18:19 S0014493.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 18:22 S0014494.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 18:24 S0014495.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 18:25 S0014496.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 18:27 S0014497.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 18:30 S0014498.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 18:32 S0014499.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 18:34 S0014500.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 18:37 S0014501.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 18:40 S0014502.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 18:44 S0014503.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 18:49 S0014504.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 18:52 S0014505.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 18:57 S0014506.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 18:58 S0014507.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 18:13 S0014508.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 18:14 S0014509.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 18:15 S0014510.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 18:16 S0014511.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 18:17 S0014512.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 18:17 S0014513.LOG
-rw-------    1 db2inst  db2igrp   524296192 10¿ù 16ÀÏ 18:18 S0014514.LOG
-rw-------    1 db2inst  db2igrp         512 10¿ù 16ÀÏ 2012  SQLLPATH.TAG

 

 

$>db2 connect to SAMPLE

 Database Connection Information

 Database server        = DB2/AIX64 9.7.3
 SQL authorization ID   = DB2INST2
 Local database alias   = SAMPLE

 

$>db2 "prune logfile prior to S0001271.LOG"
DB20000I  The PRUNE command completed successfully.


 

 

 
bash-4.2$ db2 get db cfg for SAPM

 
 Log retain for recovery status                          = NO
 User exit for logging status                            = YES




pajama 2013-10-16 23:32:57
보여주신 로그파일이 90개에 45기가정도입니다.
reorg중에 log full 메시지가 나왔다면, reorg 작업이 현재 설정된 로그파일보다 큰 트랜잭션일 수 있습니다.
전체 로그개수 설정값(logprimary+logsecond)이 아마 90이나 그 이하로 추정됩니다.

logfilsiz, logprimary, logseond 파라미터를 확인하시고 값을 늘려보십시오.
db를 재시작 할수 없다면 logsecond만 늘려보시기 바랍니다.
logprimary와 logsecond의 합은 256을 넘을수 없습니다.


728x90

'Db2 > KDUG 2013 Q·A' 카테고리의 다른 글

[인다우트 트랜젝션, XA 트랜잭션]  (0) 2013.12.23
wm_concat  (0) 2013.12.23
쿼리 구문에 대한 질문사항입니다.  (0) 2013.12.23
tablespace 관련 질문  (0) 2013.12.23
SQL 튜닝 관련 질문입니다. (IBM DB2)  (0) 2013.12.23
728x90

먹보고릴라님 | 쿼리 | 2013-10-11 18:17:22




먹보고릴라 2013-10-11 18:17:55

SELECT serialno AS AgentID, computername, IPADDR, MACADDR,
(
SELECT H.HWValue FROM avwNodeHW H, avwNode N1
WHERE N.nodeID = N1.nodeID and N1.NodeID = H.nodeID and
H.HWBaseID = (SELECT HWBaseID FROM avwHWBase WHERE HWTypeName = 'cpuNameDetail')
) AS CPU,
(
SELECT H.HWValue FROM avwNodeHW H, avwNode N1
WHERE N.nodeID = N1.nodeID and N1.NodeID = H.nodeID and
H.HWBaseID = (SELECT HWBaseID FROM avwHWBase WHERE HWTypeName = 'mainMemory')
) AS Memory,
(
SELECT H.HWValue FROM avwNodeHW H, avwNode N1
WHERE N.nodeID = N1.nodeID and N1.NodeID = H.nodeID and
H.HWBaseID = (SELECT HWBaseID FROM avwHWBase WHERE HWTypeName = 'hdd1Size')
) AS HDD1,
(
SELECT H.HWValue FROM avwNodeHW H, avwNode N1
WHERE N.nodeID = N1.nodeID and N1.NodeID = H.nodeID and
H.HWBaseID = (SELECT HWBaseID FROM avwHWBase WHERE HWTypeName = 'hdd2Size')
)AS HDD2
FROM avwNodeDetail N JOIN ATBNODE M on N.NODEID=M.NODEID


DB2 SQLDBX에서 사용 하며
에러 메시지는 
SQL0811N 스칼라 fullselect, SELECT INTO문 또는 VALUES INTO문의 결과가 두 행 이상입니다. SQLSTATE=21000
이러하게 에러 메시지가 출력 됩니다

이부분에 있어 어떻게 하는 방법이 있을까요?


먹보고릴라 2013-10-11 22:05:01
SELECT M.serialno AS AgentID, computername, IPADDR, MACADDR, H.HWValue AS CPU, H.HWValue AS MEMORY, 
H.HWValue AS HDD1, H.HWValue AS HDD2 
FROM avwNodeHW H, avwNode N1, avwNodeDetail N JOIN ATBNODE M on N.NODEID=M.NODEID
WHERE N.nodeID = N1.nodeID and N1.NodeID = H.nodeID and
H.HWBaseID in (SELECT HWBaseID FROM avwHWBase WHERE HWTypeName in ('cpuNameDetail','mainMemory'))

이렇게 수정하니 mainmemory에 cpu 이름이 같이 나와버리네요.. 
혹시 아시는 부분 있으시나용?

pajama 2013-10-11 22:14:24
안녕하세요

두가지를 확인해보시기 바랍니다.

1. 조건절에서 HWBaseID 컬럼에 아래와 같이 값을 취하는 부분이 있습니다.
H.HWBaseID = (SELECT HWBaseID FROM avwHWBase WHERE HWTypeName = '...
'=' 이기 때문에 SELECT 하는 결과 레코드가 한개 이상이면 sql0811n 오류가 발생합니다.

2. 그리고 CPU, Memory, HDD1, HDD2 컬럼값을 가져오는 스칼라서브쿼리(SELECT H.HWValue ...) 결과 레코드가 하나 이상일때도 오류가 발생합니다.

pajama 2013-10-11 22:24:20
댓글 다는 사이에 댓글을 달아주셨네요

H.HWBaseID in (SELECT HWBaseID FROM avwHWBase WHERE HWTypeName in ('cpuNameDetail','mainMemory'))
HWBaseID 컬럼에 cpu memory에 해당하는 ID를 모두 가져왔고 H.HWValue가 다 같은값으로 나올텐데요


먹보고릴라 2013-10-13 20:25:55
To. pajama 님
댓글에 감사합니다. 

두번째 댓글에서 달아주신 내용과 같이 cpumemory에 대핟ㅇ하는 ID를 가져왔는데 HWValue에서 mainMemory도 가져올려 하면
group by절로 하여 사용하면 될까요?



728x90
728x90

활발이님 | 기타 | 2013-10-08 12:57:58


tablespace에 관련해 질문 드립니다.

create tablespace의 문장에 아래와 같이 있는데

   .-MANAGED BY--AUTOMATIC STORAGE--| size-attributes |---------------------.   
>--+------------------------------------------------------------------------+-->
   '-MANAGED BY--+-SYSTEM--| system-containers |--------------------------+-'   
                 '-DATABASE--| database-containers |--| size-attributes |-'    

managed by system    - sms
                     database - dms
방식의 관리의 개념은 익히었는데

MANAGED BY--AUTOMATIC STORAGE 에 대해 질문드립니다.
1. automatic storage정의와 어떨때 사용하는 옵션인지
2. 다른 방식과의 차이점과 장점이 무엇인지 
3. 사용하기 위해 고려해야할 사항

질문 드립니다.




pajama 2013-10-08 22:16:19
1. automatic storage정의와 어떨때 사용하는 옵션인지
automatic storage는 sms와 dms형식이 혼재된 관리방식입니다.
일반테이블 스페이스는 DMS, 임시테이블 스페이스는 SMS로 생성합니다.


2. 다른 방식과의 차이점과 장점이 무엇인지
차이점이라면 테이블 스페이스를 생성할 때 스토리지 경로를 명시할 필요가 없다는 점입니다.
사용하기 쉽다는 점이 최대장점입니다. 

아래 링크는 방식별 비교표입니다.
http://pic.dhe.ibm.com/infocenter/db2luw/v10r5/topic/com.ibm.db2.luw.admin.dbobj.doc/doc/c0055446.html


3. 사용하기 위해 고려해야할 사항
처음에 데이터베이스를 생성할 때 테이블 스페이스가 생성될 스토리지 경로를 주어야합니다.
데이터베이스를 생성할 때 옵션을 주지 않아도 기본적으로 automatic storage 관리방식을 사용합니다.

활발이 2013-10-10 16:51:13
답변 감사합니다 
데이터베이스 관리 프로그램이 자동으로 데이터베이스와 연결된 모든 스토리지 경로에 컨테이너를 작성합니다 라는데 
여기서 automatic storage는 데이터가 저장되는 곳이 모든 컨테이너 디렉토리, 파일, 디바이스의 경로로 작성을 한다는 말인가요?
또한 default 경로는 어디인가요..?

pajama 2013-10-10 17:44:25
데이터베이스를 만들때(create database) 데이터베이스를 저장할 스토리지 경로를 지정합니다. 경로가 여러개가 될수도 있고요. 여러개를 지정하면 테이블스페이스 컨테이너 파일이 분산되어 저장됩니다.

활발이 2013-10-11 16:47:16
automatic storage는 경로를 명시할 필요가 없다고 했는데 데이터베이스 내에 있는 공간만 사용하는 건가요?
데이터를 저장할 공간을 db 밖에 따로 만들어서 관리할순 없나요?
(경로 명시 하지 않을시 $home/인스턴스명/NODE0000/db명/T0000005/C0000000.LRG 이런 경로로 되어 있네요)

pajama 2013-10-11 21:58:07
예를 들어 데이터베이스를 처음 생성할 때 create database sample on /DB1,/DB2 라고 했다면(스토리지 공간 명시),
테이블스페이스를 만들면 아래처럼 두개의 파일이 생깁니다.
create tablespace tbs1
/DB1/인스턴스명/NODE0000/db명/T0000005/C0000000.LRG
/DB2/인스턴스명/NODE0000/db명/T0000005/C0000000.LRG

데이터 저장공간을 /DB1,/DB2외 별도 경로로 지정하고 싶으시다면 dms,sms 형식으로 아래처럼 지정합니다.
create tablespace tbs3 managed by database using (file '/DB3/tbs3.dbf' 10M)
create tablespace tbs4 managed by system using ('/DB4')

답변이 제대로 되었는지 모르겠습니다



728x90
728x90

aegispro님 | 튜닝 | 2013-10-05 02:00:48


테이블 디자인은 아래와 같구요. (밑줄이 primary keys입니다.)
ET_STAT_DTL_TB (ET_NUMET_STAT_SEQ_NUM, ET_STAT_TS, ET_STAGE_CD, ET_STAT_CD, ET_RSN_CD, ET_ASGN_USER_ID_NUM)

원하는 결과는 ET_STAGE_CD별로 Count를 얻고 싶어요
카운드 코드
100      01
88        02
99        03
등등등..

(1) SELECT COUNT(ET_STAGE_CD), ET_STAGE_CD

FROM (
        SELECT DTL.ET_NUM, DTL.ET_STAGE_CD, DTL.ET_STAT_SEQ_NUM, 
        ROW_NUMBER() OVER(PARTITION BY DTL.ET_NUM, DTL.ET_STAGE_CD  ORDER BY                   
        DTL.ET_STAT_SEQ_NUM  DESC) ROWNUM 
        FROM SCHEMA.ET_STAT_DTL_TB DTL 
) X WHERE  ROWNUM = 1 
GROUP BY ET_STAGE_CD

(2) SELECT
COUNT(STAT.ET_STAT_CD), STAT.ET_STAGE_CD
FROM SCHEMA.ET_STAT_DTL_TB STAT
WHERE STAT.ET_STAT_SEQ_NUM =
(
   SELECT
  MAX(STAT_TMP.ET_STAT_SEQ_NUM)
  FROM NCAPRPRD.ET_STAT_DTL_TB STAT_TMP
  WHERE STAT_TMP.ET_NUM = STAT.ET_NUM     
)
GROUP BY STAT.ET_STAGE_CD WITH UR

 
첫번째 질문은 
(1)과 (2)중에서 어느쪽이 성능면에서 더 유리한지요 ? 아니면 별 차이가 없는 지요?

두번째 질문은
(1)과 (2)의 결과물이 다르게 나오는 데...(1) 혹은 (2) 쿼리에 어떠 오류가 있는 지 전문가 분들의 의견을 듣고 싶습니다




pajama 2013-10-06 22:52:37
인덱스나 레코드수 등에 따라 차이는 있겠지만 두번째는 조인이 발생하기 때문에 비용발생이 커질 여지가 있습니다. 실행계획을 보는 것이 확실합니다. 그리고 두번째 쿼리문이 COUNT값이 ET_STAT_CD 컬럼으로 쓰셨는데 ET_STAGE_CD 컬럼을 잘못 쓰신건가요?

aegispro 2013-10-07 11:54:20
예 지적하신대로 ET_STAGE_CD가 맞아요. 제가 잘 이해가 가지 않는 부분은 (1)과 (2)의 결과가 조금 다르다는 것입니다. 
제가 무엇인가를 잘못 이해하고 있는 것인지 ... 몇시간째 고민하고 있는 데 답이 나오지 않아서요. (1)은 정확한 결과를 리턴해 주는 데 (2)는 특정 ET_NUM에 대해서는 아예 blank로 결과값이 나타납니다. 혹시 이부분 
WHERE STAT.ET_STAT_SEQ_NUM =
(
SELECT
MAX(STAT_TMP.ET_STAT_SEQ_NUM)
생략...
에서 문제가 발생할 여지가 있는 지요?

pajama 2013-10-07 17:20:59
죄송합니다. 말씀하신 내용이 좀 헷갈려서요.
결과값이 blank라는 말씀이 max함수값이 null 값이라는 말씀이신가요?

SELECT
MAX(STAT_TMP.ET_STAT_SEQ_NUM)
FROM NCAPRPRD.ET_STAT_DTL_TB STAT_TMP
WHERE STAT_TMP.ET_NUM = STAT.ET_NUM 

max값이 null이라면 테이블 조인 결과세트, 또는 특정 ET_NUM에 해당하는 결과세트가 없다는 의미입니다. (건수 0)

그리고 NCAPRPRD.ET_STAT_DTL_TB 테이블이 SCHEMA.ET_STAT_DTL_TB STAT 테이블과 동일한 테이블인가요?

aegispro 2013-10-07 21:11:12
(1) 예 동일한 테이블 맞아요 그러니까 셀프 Join입니다.
(2) 특정 ET_NUM의 결과가 다를 수 있을 까요 (위 두개의 다른 쿼리가요? 그러니까 Partition BY를 쓰는 것과 사용하지 않는 것)

pajama 2013-10-08 00:18:14
테스트로 데이터를 만들어서 해보았습니다 테이블 데이터타입이나 값은 무작위로 넣었습니다.
우선 첫번째 쿼리에서 PARTITION BY 절에서 ET_NUM과 ET_STAGE_CD 컬럼을 기준으로 정렬을 하셨는데요
서브쿼리에서 조인할때는 ET_NUM 컬럼으로만 조인해서 결과값이 다른 것으로 보입니다.

SELECT
COUNT(STAT.ET_STAGE_CD), STAT.ET_STAGE_CD
FROM SCHEMA.ET_STAT_DTL_TB STAT
WHERE STAT.ET_STAT_SEQ_NUM =
(
SELECT
MAX(STAT_TMP.ET_STAT_SEQ_NUM)
FROM NCAPRPRD.ET_STAT_DTL_TB STAT_TMP
WHERE STAT_TMP.ET_NUM = STAT.ET_NUM
AND STAT_TMP.ET_STAGE_CD = STAT.ET_STAGE_CD
)
GROUP BY STAT.ET_STAGE_CD WITH UR

제가 테스트한 결과로는 이렇게 했을때 동일한 결과가 나왔습니다.

aegispro 2013-10-08 02:12:15
아하 그렇군요. 정확하게 잘못을 지적해 주셨네요. 더 나은 대안이 없다면 성능 문제 때문에 첫번째 쿼리로 가야 할 것 같습니다. 혹시 더 나은 방법을 알고 계시는 지요?

pajama 2013-10-08 22:19:36
쿼리작성은 제가 미진하여 조언드리기가 어렵습니다. 질문주셔서 오히려 제가 공부가 되었네요



728x90
728x90

LOUPOS님 | 튜닝 | 2013-10-04 18:09:30

 

인덱스도 잘타고.. 코스트도 페치하기 전엔 10-20 정도에.. 최종코스트 50정도면 작은거 같은데.. 
리스트뽑아올때 30초씩걸리는 이유 아시는분...(1분걸림..)


해당 테이블 참조를 3개를 참조해서 가져오는건데...
3개다 각각 인덱스 다 잘타고...

다만... 각 테이블 레코드수가 많긴한데.. 2천만건정도...
그중 뽑아올 레코드는 약 200만~300만 레코드...(최대)
(근대 200만건이 많아서 안댄다 그러면....ㅠ)

문제는 레코드수가 많다고 처리속도가 늦는건 DB구조상 인덱스를 잘 타는데 저정도로 느릴수 있나요.. 이걸 개선하려면 어케 해야하나요..

액세스 플랜도 깔끔하니 잘나오고.. 조인도 최소로 조인시켜서 코스트 높게 안잡히는데.... 전체레코드수때문일까요...
범위형 조건이 많긴 한데.. 인덱스 다 타구요... 다만, 범위를 진짜 타이트하게 잡아서 출력레코드를 100만건 이하로 줄이면 1초만에 뽑히는 걸로 보아.. 레코드수 문제가 맞는거 같기도 하고...

DB전문가의 손길을 요합니다...
(진짜 하다하다 안대서.. 여기에 올려봅니다..IBM DB2 메뉴얼 다뒤져가면서 하는중 ㅠ)

 

 

  LOUPOS 2013-10-04 18:17:47  
액세스플렌 이미지 캡쳐 포함시켰습니다...

의심스러운 것은 토드에서 쿼리 수행시에 최초 100만레코드는 3초 정도만에 긁어 오는데 여기서부터 퍼포먼스가 쫙 떨어지면서
150만 레코드 부터는 1000레코드 긁어오는데 3초 이상씩 걸립니다...(동영상찍어서 올려야대나요..ㅋㅋ;;)

이거때문에 메모리나 CPU IO 부분 할당량이 적은가 했는데

메모리 32GB에 DB2 할당량 22GB정도 잡히고.. 실 사용율 CPU 5%도 안됩니다...
저거 다 쓰지도 못하면서 이러네요...(못긁겠으면 하드웨어 팍팍 쓰라고...ㅠ)

답변부탁드립니다 ㅠ
 
 
 
 
  pajama 2013-10-04 22:24:42  
안녕하세요? 실행하는 쿼리에 비해 Cost값이 너무 낮게 나오는것이 이상합니다. 
샘플DB에서 1만건 단순 조회만 해도 Cost값이 300정도 나옵니다.
각 테이블에 대해 통계정보갱신(RUNSTATS) 실행이 최근에 언제 되었는지 확인해보십시오.
 
 
 
 
  LOUPOS 2013-10-07 11:48:55  
으아...그러네요... 리오그 하고 범위설정을 다시했더니
최종적으로 300만 코스가....발생을...하아...

그리고 데이터레코드가 200만건이나 되는데 NL조인 할리가 없죠... 해쉬조인으로 바뀌었네요...
이거 개선 방법이 없을까요?

이곳저곳에서 자분을 구해봐도...
원천데이터(통계적 데이터가 아닌 스트링데이터) 를 불러오는데 그건 당연한거다 이러는데.. 이게 맞나요?
 
 
 
 
  pajama 2013-10-07 16:28:50  
해시조인 성능을 개선하려면 DB파라미터(sortheap, sheapthres) 설정값을 늘려주는 방법이 있습니다.

 

 

115500.png
0.05MB
728x90
728x90

활발이님 | 기타 | 2013-10-04 00:44:03


버퍼풀과 tablespace에 대해 보기 시작하였는데 
옵션이나 값 설명에 이해가 안되는 부분이있어 질문드립니다
4가지네요... 답변 부탁드리겠습니다.

1. inbdefaultbp 버퍼풀의 npages가 bufferpool의 page수를 의미하는 것 같은데 값이 기본으로 -2가 되어있는데 이 의미는?
(SELECT * FROM SYSCAT.BUFFERPOOLS 조회시)

2.tablespace의 pagesize (4k, 8k,16,18) 별로 temporary tablespace를 생성해 주여야 되는데
  만약 8k짜리 tablespace를 만들고 8k짜리 temp tablespace를 만들지 않았을때의 문제는 뭐었이 되는지?
  sql이 수행될떄 임시 저장되는 공간이 없어서 그냥 수행되는 속도의 차이만 문제가 되는지...

3.TABLESPACE 유형에 USER TEMPORARY TABLESPACE가 기본 DEFAULT로 생성되면 USERSPACE1인가요?

4. tablespace의 욥션에 no file system caching와 file system caching 는 어떤 기능인가?




pajama 2013-10-04 01:59:01
1. inbdefaultbp 버퍼풀의 npages가 bufferpool의 page수를 의미하는 것 같은데 값이 기본으로 -2가 되어있는데 이 의미는?
(SELECT * FROM SYSCAT.BUFFERPOOLS 조회시)
npages 값이 -2인 경우는 버퍼풀에 자체 튜닝 기능을 사용중임을 의미합니다. (자동 크기 조정)
http://publib.boulder.ibm.com/infocenter/db2luw/v10r1/topic/com.ibm.db2.luw.admin.perf.doc/doc/t0021635.html


2.tablespace의 pagesize (4k, 8k,16,18) 별로 temporary tablespace를 생성해 주여야 되는데
만약 8k짜리 tablespace를 만들고 8k짜리 temp tablespace를 만들지 않았을때의 문제는 뭐었이 되는지?
sql이 수행될떄 임시 저장되는 공간이 없어서 그냥 수행되는 속도의 차이만 문제가 되는지...

소트나 조인수행시 작업 공간이 없어서 sql수행자체가 되지 않을 수 있습니다. (아래 오류 메시지 참조)
SQL1585N A system temporary table space with sufficient page size does not
exist. SQLSTATE=54048
http://publib.boulder.ibm.com/infocenter/db2luw/v10r1/topic/com.ibm.db2.luw.admin.dbobj.doc/doc/c0052067.html


3.TABLESPACE 유형에 USER TEMPORARY TABLESPACE가 기본 DEFAULT로 생성되면 USERSPACE1인가요?
USERSPACE1은 데이터베이스 생성시 자동으로 생성되는 일반 테이블 스페이스입니다.
사용자 임시 테이블 스페이스(USER TEMPORARY TABLESPACE)는 직접생성해야 합니다.


4. tablespace의 욥션에 no file system caching와 file system caching 는 어떤 기능인가?
파일시스템 캐시는 디스크에서 읽어온 데이터를 저장하는 메모리 공간을 의미합니다.
file system caching 옵션을 사용하면 파일시스템캐시에 있는 데이터를 db2의 버퍼풀로 다시 이동시킵니다.
no file system caching 옵션을 사용하면 버퍼풀에 바로 디스크에서 읽어온 데이터를 복사합니다.
파일시스템 캐시는 주로 inline 옵션이 아닌 LOB 데이터나, 임시테이블스페이스 데이터에서 사용합니다.
http://publib.boulder.ibm.com/infocenter/db2luw/v10r1/topic/com.ibm.db2.luw.admin.dbobj.doc/doc/c0051304.html
http://www.ibm.com/developerworks/data/library/techarticle/dm-0509wright/
http://www.ibm.com/developerworks/data/library/techarticle/dm-1204concurrent/

활발이 2013-10-04 02:15:55
늦은 시간에 답변주시다니.. 자세한 답변 감사드립니다. 질문 밑에 url도 자세히 살펴보겠습니다~



728x90
728x90

DB는내운명님 | 백업 | 2013-09-27 11:33:27


db2 복원 시, 

백업본으로 restore 후 아카이브 로그로 rollforward를 합니다.

그런데,, 만약 아카이브 로그가 손상이 됬을 경우... rollrforward가 정상적으로 진행이 되나요?

제가 알기로는 로그가 깨져있으면 진행이 되지 않는것으로 알고 있습니다. 

또한 아카이브 로그가 손상되었다면..아카이브 로그 백업 본으로 복원을 하는건가요? 

실제 필드에서는 어떻개 진행을 하고 있나요? 

 아카이브 로그 복원은 어떻게 하나요? 

제가 알고 있는게 맞는건지 조언 부탁 드립니다.




pajama 2013-09-28 01:07:09
아카이브 로그 파일이 손상 되었다면 시점(point-in) 복구를 해야합니다.


728x90
728x90

활발이님 | 기타 | 2013-09-26 22:10:36


이제 막 db2를 시작하는 사람입니다
또한 제목 이외에 몇가지 더 질문 드립니다.
초보적인 질문이지만 답변 부탁드리겠습니다!

1. database에 붙는 application을 list applications 으로 확인을 하는데
 이 application이 어디서 db로 붙은지 확인을 어떻게 하는지 알고 싶습니다.

2. das user를 생성해서 db2admin start/stop 로 시작 및 중지를 하는데요
 제어 센터나 gui도구를 이용해 db2를 운영할때 필요한 특수 인스턴스가 das인데 
 이 인스턴스는 그냥 start 시키면 이 기능이 오토매틱으로 되는건지...
 제어센터 및 도구를 사용하기 위해 어떠한 설정이 필요한지 알고싶습니다

 답변 부탁드립니다.




pajama 2013-09-27 00:46:16
1. list application 명령에서 application id에 클라이언트의 IP가 표시됩니다.
$ db2 list applications

Auth Id Application Appl. Application Id DB # of
Name Handle Name Agents
-------- -------------- ---------- -------------------------------------------------------------- -------- -----
DB2INS97 db2jcc_applica 6747 175.114.54.157.2239.130926153847 SAMPLE 1
DB2INS97 db2bp 6640 *LOCAL.db2ins97.130926144511 SAMPLE 1

상세정보는 아래와 같은 명령으로 확인합니다.
$ db2 get snapshot for application applid 175.114.54.157.2239.130926153847
$ db2pd -db sample -api 6747

2. 제어센터를 사용하실때 db2admin start 이외에 별도로 설정하실 작업은 없습니다.
das는 DB 인스턴스와는 별도로 시작, 종료합니다. 시스템 시작시 자동으로 실행되게 하려면 dasauto명령으로 설정합니다.

활발이 2013-09-27 14:59:45
답볌 감사합니다~ 도움이 되었습니다!



728x90

+ Recent posts