본문 바로가기

oracle6

[Oracle/Tibero] merge insert 누락된 우괄호 MERGE INTO 테이블명 USING DUAL ON ( 키속성1 = #{인자값} , 키속성2 = #{인자값} ) WHEN MATCHED THEN UPDATE SET 입력할속성값1 = #{인자값} , 입력할속성값2 = #{인자값} WHEN NOT MATCHED THEN INSERT ( 속성값1 , 속성값2 , ... ) VALUES ( #{인자값} , #{인자값} , ... ) Merge문으로 데이터베이스에 단말과의 현재 연결 상태를 업데이트 처리를 하거나 받은 데이터를 입력하는 부분이 있는데 통신으로 받은 데이터들을 DB에 입력하는 동작에서 try catch문으로 감싸서 동작시키는데도 아무런 반응이 없어서 SQL문을 살펴보았다. 위에서 잘못된점은 현재 Using DUAL on ~뒤에 오는 키값에서 조건.. 2021. 6. 2.
오라클 상위 몇개 가져오기 MYSQL에서는 간단하게 LIMIT 을 이용해서 출력된 결과 중 최상위부터 몇개까지의 데이터를 가져올 수 있다. 오라클에서 rownum이라는걸 지원한다고는 알고 있었고 이를 이용하면 된다고는 어렴풋이 알고있었으나 감이 잡히지 않아서 못쓰고 있던 속성이었다. 하지만 오늘 적당한 기회가 되어 직접 사용하면서 결과문을 확인해보어 알게되었다. 이력테이블에서 where 조건을 걸어서 상위 몇개만 출력하고 싶었던경우가 몇번 있었는데 그럴때마다 이력테이블의 시간 속성에 조건을 걸어주고 검색을 했었는데 이젠 그럴필요가 없어졌다. SELECT ROWNUM, A.* FROM (SELECT * FROM 이력테이블 A ORDER BY 시간속성명 DESC ) A WHERE ROWNUM 2021. 5. 18.