PC를 포맷하고 개발 세팅을 쭉쭉 하고 있다.

오라클 클라이언트 12.1.0.2 (32bit) 이 녀석 설치하다 왠걸 그전에 아무 문제 없이 설치 되던게 갑자기 안되네?

뭐 이런 경우가 하나둘인가... 찬찬히 구글링을 했다.

visual studio 2013 redistributable 관련 이슈가 있다하여

Download Visual Studio 2013용 Visual C++ 재배포 가능 패키지 from Official Microsoft Download Center

위 사이트에서 다운받아 설치를 했다. x64, x86 둘 다 해봤다. 안되더라 ㅠ

그러다 또 찾고 찾았다. 그러던중

오라클 설치 창 사라지는 오류 해결하기  < 여기 사이트 발견... 오 뭔가 그럴싸 한데....

막 따라했다.

레지스트리(regedit) : 

HKEY_LOCAL_MACHINE\SOFTWARE\WOW6432Node\ORACLE

마지막 ORACLE 키가 없다면 생성하고 아래 그램의 우측 문자열값에 inst_loc도 생성 시켜주자

그리고 해당 값에는 C:\Program Files (x86)\Oracle\Inventory 입력

그리고 재설치 하니 되네... 이놈의 오라클은 설치도 삭제도 참 번거롭고 귀찮다.

64bit 환경에서 32bit 오라클 클라이언트를 설치하려니 발생하는 경로상의 문제로 여겨진다.

이렇게 삽질을 하다보면 참 느끼는게 있다.

알고보면 참 별거 아닌데 알기까지가 힘들고 자주 접하지 않다 보니 비슷한걸 또 하게 되면 분명 까먹게 돼서 어떻게 했더라? 어디에 있었더라? 항상 찾게 된다.

그래서 기억력이 부족한 나는 기록해 둔다.

다음에는 삽질을 줄여나가기 위해서...

 


WRITTEN BY
테네시왈츠
항상 겸손하게 항상 새롭게 항상 진실하게

,

From부터 To까지 날짜를 대입하면 그 사이 날짜를 가져오면 유용한 시스템함수

MASTER..SPT_VALUES

    SELECT CONVERT(VARCHAR, DATEADD(D, NUMBER, '2023-01-03'), 112) DATE  
        FROM MASTER..SPT_VALUES  
        WHERE TYPE = 'P'  
        AND NUMBER <= DATEDIFF(D, '2023-01-03', '2023-02-03')  

 


WRITTEN BY
테네시왈츠
항상 겸손하게 항상 새롭게 항상 진실하게

,

[접속]

윈도우 command에서 sqlplus / as sysdba 명령어 입력하여 접속

 

[작업 테이블 스페이스 지정]

기존에 만들어진 tablespace 정보 확인

SQL> SELECT tablespace_name, bytes, file_name FROM dba_data_files;

 

저장된 곳을 확인했으면 그곳에 200M 정도의 테이블스페이스를 만든다.

SQL > CREATE TABLESPACE 테이블스페이스명

2 DATAFILE 'C:\ORACLE\PRODUCT\10.2.0\ORADATA\PIWMDB\PIWM01.DBF' size 200M;

 

 

[계정 생성]

SQL> CREATE USER 생성할 계정 이름 

2 IDENTIFIED BY 계정 비밀번호

3 DEFAULT TABLESPACE 테이블스페이스명

3 QUOTA UNLIMITED ON 테이블스페이스명;  // 테이블스페이스의 제한량 무한대

 

[계정에 대한 권한 설정]

GRANT CREATE SESSION, CREATE TABLE, CREATE SEQUENCE, CREATE VIEW TO 권한을 줄 계정명;

  

 

 

 

[테이블 스페이스 조회]

SELECT * FROM DBA_TABLESPACES;

 

[접속 권한 부여 (DML, DDL)]

GRANT RESOURCE, CONNECT TO 권한 받을 계정;

 

[SYNONYM 생성 권한 부여]

GRANT SYNONYM TO 권한 줄 계정명;

 

[테이블 권한 부여]

GRANT SELECT, INSERT, UPDATE, DELETE ON 권한 줄 테이블명 TO 권한 받을 계정;

 

[SYNONYM 생성]

CREATE SYNONYM 계정명.테이블명 FOR 테이블 소유자 계정명.테이블명;

  

[FUNCTION 실행 권한 부여]

GRANT EXECUTE ON 권한 줄 함수명 TO 권한 받을 계정;

 

[계정 삭제]

DROP USER  삭제할 계정 CASCADE;

 

[현재 계정 조회]

SELECT USER FROM DUAL;

 

[오라클 전체 테이블 권한 부여]

SELECT 'GRANT SELECT ON 테이블소유계정.'||TABLE_NAME || ' TO 권한을 줄 계정명;'

FROM ALL_TABLES WHERE OWNER = '테이블소유계정'



출처: https://artwook.tistory.com/244 [나비의 블로그]

 

------------------------------------------------------------------------------

티베로 작업시 필요로한 내용이다. 우연히 구글링하다 좋은 포스팅 발견하여 퍼왔다.


WRITTEN BY
테네시왈츠
항상 겸손하게 항상 새롭게 항상 진실하게

,

오라클 패키지 혹은 프로시저 호출시 동일하게 여러건 반복적으로 호출하는 경우가 있다.

이는 트랜잭션에 문제가 될 소지도 있고 DB처리 시간도 고려해 문자형 변수에 ';' 을 끝에 붙여

한방에 처리하는 구조가 훨씬 간결하다고 판단된다.


FOR C1 IN ( SELECT LEVEL AS R_INDEX
                        , REGEXP_REPLACE (REGEXP_SUBSTR ('AAA;BBB;CCC;DDD;','(.*?)' || ';', 1, LEVEL), '[;]', '') AS ABCD
                 FROM DUAL X1
            CONNECT BY REGEXP_INSTR ('AAA;BBB;CCC;DDD;', '(.*?)' || ';', 1, LEVEL) > 0 )
LOOP
 --
END LOOP;


WRITTEN BY
테네시왈츠
항상 겸손하게 항상 새롭게 항상 진실하게

,

-- 특정 기간 표시(2018-08-19 ~ 2018-08-29)

SELECT TO_CHAR( TO_DATE( '20180819', 'YYYYMMDD' ) + LEVEL-1, 'YYYYMMDD' ) AS DAY    

FROM DUAL 

CONNECT BY LEVEL <=( TO_DATE( '20180829', 'YYYYMMDD' ) - TO_DATE( '20180819', 'YYYYMMDD' ) +1 )


DAY

20180819

20180820

20180821

20180822

20180823

20180824

20180825

20180826

20180827

20180828

20180829


-- 금일 24시간 표시

SELECT TO_CHAR(SYSDATE, 'YYYYMMDD')||LPAD(LEVEL-1, 2, '0') AS DT 

FROM DUAL CONNECT BY LEVEL-0 < 25;


DT

2018082900

2018082901

2018082902

2018082903

2018082904

2018082905

2018082906

2018082907

2018082908

2018082909

2018082910

2018082911

2018082912

2018082913

2018082914

2018082915

2018082916

2018082917

2018082918

2018082919

2018082920

2018082921

2018082922

2018082923



-- 다음과 같이 JOIN 을 이용하여 단순화(?) 할 수 있음

SELECT TO_CHAR( TO_DATE( S, 'YYYYMMDD' ) + LEVEL-1, 'YYYYMMDD' ) AS DAY

FROM (SELECT '20180819' S, '20180829' E FROM DUAL)

CONNECT BY LEVEL <=( TO_DATE( E, 'YYYYMMDD' ) - TO_DATE( S, 'YYYYMMDD' ) +1 );


WRITTEN BY
테네시왈츠
항상 겸손하게 항상 새롭게 항상 진실하게

,

SELECT A1.TABLE_COMMENTS

     , A1.TABLE_NAME

--     , A1.COLUMN_ID

     , A1.COLUMN_NAME AS COLUMN_ID

     , A1.COLUMN_COMMENTS AS COLUMN_NAME

     , A1.DATA_TYPE AS DATA_TYPE     

     , (CASE A1.DATA_TYPE WHEN 'NUMBER' THEN TO_CHAR(A1.DATA_LENGTH)

                                        WHEN 'DATE'   THEN ' ' 

                                        ELSE TO_CHAR(A1.DATA_LENGTH) END) AS DATA_LENGTH

     , NVL(A1.NULL_FLAG, 'N') AS NULL_FLAG                              

     , (CASE WHEN B1.CONSTRAINT_TYPE = 'P' THEN 'PK' END) PK_FLAG

  FROM (SELECT B.COMMENTS TABLE_COMMENTS

             , A.TABLE_NAME TABLE_NAME

             , C.COMMENTS COLUMN_COMMENTS

             , A.COLUMN_NAME COLUMN_NAME

             , (CASE A.NULLABLE WHEN 'Y' THEN 'Y' END) NULL_FLAG

             , A.DATA_TYPE DATA_TYPE

             , A.DATA_LENGTH 

             , A.COLUMN_ID AS COLUMN_ID

             , A.DATA_PRECISION

        FROM USER_TAB_COLUMNS A

           , USER_TAB_COMMENTS B

           , USER_COL_COMMENTS C

       WHERE (A.TABLE_NAME = B.TABLE_NAME)

         AND (A.TABLE_NAME = C.TABLE_NAME AND A.COLUMN_NAME = C.COLUMN_NAME )

         AND B.TABLE_TYPE = 'TABLE') A1

           , ( SELECT A.TABLE_NAME

                    , A.COLUMN_NAME

                    , B.CONSTRAINT_TYPE

                 FROM USER_CONS_COLUMNS A

                    , USER_CONSTRAINTS B

                WHERE (A.CONSTRAINT_NAME = B.CONSTRAINT_NAME)

                  AND B.CONSTRAINT_TYPE IN ('P', 'R')) B1

 WHERE (A1.TABLE_NAME = B1.TABLE_NAME(+)

   AND A1.COLUMN_NAME = B1.COLUMN_NAME(+))

  --AND A1.TABLE_NAME LIKE 'TBL%'

 ORDER BY A1.TABLE_NAME, A1.COLUMN_ID;


WRITTEN BY
테네시왈츠
항상 겸손하게 항상 새롭게 항상 진실하게

,

오늘 급히 오라클 세션을 강제로 종료할 일이 발생했다.

오라클 Job의 다음 실행일시를 변경해 주는 작업인데

나는 주로 SqlDeveloper를 사용하는데 이 Tool로 변경해 주었더니 제대로 먹히지가 않았었다.

난 당연히 잘 돌았겠지 했는데 좌절감을 맛 보았다.

 

그래서 Toad를 이용하여 다음 실행일시를 변경할려고 하는데 오랫만에 Toad를 열어보니 이 마저도 만만치 않는거다

다시 SqlDeveloper로 돌아와 변경을 하고 Toad에서 확인을 해보려 강제 실행을 했더니...

그 순간 아무런 반응이 없더니 늘 그렇듯 또 어..어.. 왜 이러지... 왜 이러지... db에 문제 생길까봐 얼른 강제로 세션

종료하는 구문을 찾아야만 했다.

 

그래서 나온 답이 아래와 같다.

SELECT * FROM V$SESSION WHERE STATUS = 'ACTIVE' AND USERNAME IS NOT NULL;
ALTER SYSTEM KILL SESSION '4,9839'; -- 'SID, SERIAL#'


WRITTEN BY
테네시왈츠
항상 겸손하게 항상 새롭게 항상 진실하게

,

무료하던 나의 일상에 흥미(?)로운 내용을 발견하게 돼 포스팅 하게 된다.

 

2년전쯤 개발한 사이트의 사용자 테이블 암호화 작업을 추가해야 하는데 고객의 급한(?)요구가 있어 관련된 내용이 무엇이 있을까 살펴 보았더니 딱 이거다 하는 내용이 있어 내용을 분석/파악하여 방금전 운영에 반영을 하고 왔다.

 

기존 Password컬럼에 비밀번호가 고스란히 표시가 되었고 이부분을 암호화하여 저장하여 향후 유지관리 될 수 있도록 학는게 목표였는데 MS-SQL에 PWDENCRYPT, PWDCOMPARE 함수를 이용하였다.

사실 좀 아쉬운 점은 암호화는 되지만 복호화 부분이 참일경우 '1', 거짓일 경우 '0' 경우라 제한적인 부분이란 것이다.

로그인이 '1' 일 때는 성공, '0' 일 때는 실패로 처리하여 별 무리 없이 진행은 되었다.(그래도 아쉬워 ㅠ)

 

중요한 점은 Password가 저장될 컬럼이 VARCHAR형태가 아닌 VARBINARY 형태로 저장을 하여야 이용을 할 수 있는 점이 특징이다.

 

개발하랴 유지보수 업무 하랴 바쁘다 바빠 하앍하앍~~

 


CREATE TABLE MEMBER (
 USERID VARCHAR(10),
 USERPASSWORD VARBINARY(100)
);

 

INSERT INTO MEMBER(USERID, USERPASSWORD) VALUES ('aa', PWDENCRYPT('1111'));

 

SELECT USERID, USERPASSWORD, PWDCOMPARE('1111', USERPASSWORD) FROM MEMBER;

=============

aa | 1111 | 1

 

 

참고 사이트 : http://ladon.tistory.com/18


WRITTEN BY
테네시왈츠
항상 겸손하게 항상 새롭게 항상 진실하게

,

힌트다 힌트!


사용방법은 아래와 같다.


SELECT /*+ INDEX( IDX_COL_1 ) */

       NAME

     , AGE

     , HOBBY

  FROM MEMBER;


힌트의 종료와 사용방법은 아주 다양하고 무수히 많다.

물론 다 이해하고 사용하는 것이 맞겠지만


우선 쉬운 개념부터 잡아 나가자.

힌트를 잘못 쓰면 안쓰느만 못하는 그런 사태가 안벌어 지게 잘 이해하고 잘 사용하도록 하자.


WRITTEN BY
테네시왈츠
항상 겸손하게 항상 새롭게 항상 진실하게

,

오라클 LOCK 걸린 SQL을 찾아라

 


SELECT /*+ ORDERED */
       A.SID SID
     , TO_CHAR(B.SERIAL#) SEQ
     , ID1 ID1
     , TO_CHAR(B.AUDSID) AUD
     , B.USERNAME UNAME
     , B.OSUSER OSUSER
     , C.SQL_TEXT SQLSTMT
  FROM V$LOCK A
     , V$SESSION B
     , V$SQL C
 WHERE A.TYPE = 'TM'
   AND A.SID = B.SID
   AND C.HASH_VALUE(+) = B.SQL_HASH_VALUE;

 

 

SESSION KILL을 아래와 같이

ALTER SYSTEM KILL SESSION 'SID, SERIAL#'

 

 

 

 

참고 : http://nizistyle.tistory.com/4

 


WRITTEN BY
테네시왈츠
항상 겸손하게 항상 새롭게 항상 진실하게

,