UUID 함수
·
Oracle/SQL
Oracle 23ai(23.9)에 UUID 함수가 추가되었습니다. UUID 함수는 version 4 variant 1 UUID를 RAW(16) 형식의 값으로 반환합니다. 아래는 UUID 함수를 사용한 예제입니다. UUID 함수는 SYS_GUID 함수와 달리 로우 별로 다른 값을 반환합니다.-- 1SELECT UUID () AS uuid , SYS_GUID () AS sys_guid FROM XMLTABLE ('1 to 2');UUID SYS_GUID-------------------------------- --------------------------------67674554354B4FD7BF7EDEB601A3B609 3A1B91494C76C2..
INSERT SET 절과 BY NAME POSITION 절
·
Oracle/SQL
Oracle 23ai(23.9)부터 INSERT 문에 INSERT SET 절과 BY NAME POSITION 절을 사용할 수 있습니다. 테스트를 위해 아래와 같이 테이블을 생성하겠습니다.-- 1DROP TABLE t1 PURGE;DROP TABLE t2 PURGE;CREATE TABLE t1 (c1 NUMBER, c2 NUMBER);CREATE TABLE t2 (c1 NUMBER, c2 NUMBER, c3 NUMBER); 아래는 INSERT 문에 INSERT SET 절을 사용한 예제입니다. INSERT VALUES 절보다 명시적으로 칼럼과 값을 지정할 수 있어 오류 가능성을 줄일 수 있습니다. 주석 처리된 형식으로도 INSERT SET 절을 사용할 수 있습니다.-- 2-1INSERT INTO t1 SET..
GROUP BY ALL
·
Oracle/SQL
Oracle 23ai(23.9)부터 GROUP BY ALL 절을 사용할 수 있습니다. GROUP BY ALL 절을 사용하면 집계 함수를 사용하지 않은 표현식을 기준으로 결과가 그룹핑됩니다. 테스트를 위해 아래와 같이 테이블을 생성하겠습니다.-- 1DROP TABLE t1 PURGE;CREATE TABLE t1 (c1, c2) AS SELECT CEIL (ROWNUM / 100), CEIL (ROWNUM / 10) FROM XMLTABLE ('1 to 1000'); 아래는 GROUP BY ALL 절을 사용한 예제입니다. 집계 함수를 사용하지 않은 표현식을 기준으로 결과가 그룹핑되는 것을 볼 수 있습니다.-- 2-1SELECT COUNT (*) AS cnt FROM t1 GROUP BY ALL; CNT---..
TIME_BUCKET 함수
·
Oracle/SQL
Oracle 23ai(23.7)에 SQL Time Bucketing 기능이 추가되었습니다. 이 기능을 사용하면 시계열 데이터를 특정 간격(버킷)으로 집계 분석할 수 있습니다. TIME_BUCKET 함수는 입력 날짜 값를 특정 원점에 맞춰 지정된 간격으로 버킷화하여 버킷의 시작 부분을 반환합니다. 아래는 TIME_BUCKET 함수의 구문입니다. 첫 번째 인수는 입력 날짜 값, 두 번째 인수는 간격, 세 번째 인수는 원점, 네 번째 인수는 버킷의 시작 또는 끝을 반환할지 여부(기본값은 START), 다섯 번째 인수는 월말일에 대해 버킷을 결정하는 방식(기본값은 ON OVERFLOW ROUND)을 입력합니다.TIME_BUCKET (datetime, stride, origin, [ START | END ] [ ..
ORA-01719 에러
·
Oracle/SQL
Oracle 23ai부터 IN 조인 조건에 대해 ORA-01719 에러가 발생하지 않습니다. 아래는 V$SYSTEM_FIX_CONTROL 뷰에서 ORA-01719 에러와 관련된 Fix Control을 조회한 결과입니다.SELECT bugno, value, sql_feature, description, optimizer_feature_enable FROM v$system_fix_control WHERE bugno IN (6610822, 32436948); BUGNO VALUE SQL_FEATURE DESCRIPTION OPTIMIZER_FEATURE_ENABLE-------- ----- -----------..
SQL Macro - Table Expression
·
Oracle/SQL
지난 글에 이어 이번 글에서는 테이블 표현식을 사용하는 테이블 SQM에 대해 간단히 살펴보겠습니다. 참고로 테이블 SQM은 Oracle 19c에 추가된 PTF(Polymorphic Table Function)과 유사하게 동작하며, SQL Server의 TVF(Table-Valued Function)을 대체할 수 있는 기능으로 보입니다. 테스트 버전은 아래와 같습니다. 테이블 SQM은 19.7 버전으로 기능이 backport되었습니다.-- 1SELECT version_full FROM product_component_version;VERSION_FULL------------21.3.0.0.01 row selected. 테스트를 위해 아래와 같이 테이블을 생성하겠습니다.-- 2DROP TABLE t1 PUR..
SQL Macro - Scalar Expression
·
Oracle/SQL
Oracle 21c에 SQL Macro(SQM) 기능이 추가되었습니다. SQM을 사용하면 SQL 표현식(스칼라 표현식)과 SQL 문(테이블 표현식)을 재사용 가능한 매개변수화된 구조로 변환할 수 있습니다. 이번 글에서 스칼라 표현식을 사용하는 스칼라 SQM에 대해 간단히 살펴보겠습니다.You can create SQL macros (SQM) to factor out common SQL expressions and statements into reusable, parameterized constructs that can be used in other SQL statements.SQL macros can either be scalar expressions, typically used in SELECT lis..
분석 함수 기능 개선
·
Oracle/SQL
Oracle 21c에서 분석 함수의 기능이 개선되었습니다. 이번 글에서 관련 내용을 살펴보겠습니다. 준비테스트 버전은 아래와 같습니다.-- 1SELECT version_full FROM product_component_version;VERSION_FULL------------21.3.0.0.01 row selected. 테스트를 위해 아래와 같이 테이블을 생성하겠습니다.-- 2DROP TABLE t1 PURGE;CREATE TABLE t1 (c1 NUMBER, c2 NUMBER);INSERT INTO t1 VALUES (1, 1);INSERT INTO t1 VALUES (2, 1);INSERT INTO t1 VALUES (3, 2);INSERT INTO t1 VALUES (4, 2);INSERT INTO..
Interval 값을 초로 변환
·
Oracle/SQL
Oracle은 Interval 값을 초로 변환할 때 아래와 같이 다소 복잡한 계산식을 사용해야 합니다.-- 1SELECT ts2 - ts1 AS int , EXTRACT (DAY FROM ts2 - ts1) * 60 * 60 * 24 + EXTRACT (HOUR FROM ts2 - ts1) * 60 * 60 + EXTRACT (MINUTE FROM ts2 - ts1) * 60 + EXTRACT (SECOND FROM ts2 - ts1) AS sec FROM (SELECT TIMESTAMP '2050-01-01 00:00:00.000000000' AS ts1 , TIMESTAMP '2050-02-01 00:00:00.123456789' AS ts..
현재 세션 SERIAL 번호 조회
·
Oracle/SQL
SYS_CONTEXT 함수는 현재 세션의 SERIAL 번호를 조회할 수 있는 파라미터를 제공하지 않습니다. 아래와 같이 DBMS_DEBUG_JDWP 패키지의 CURRENT_SESSION_SERIAL 함수를 사용하면 현재 세션의 SERIAL 번호를 조회할 수 있습니다.SELECT inst_id , sid , serial# , DBMS_DEBUG_JDWP.CURRENT_SESSION_ID AS current_session_id , DBMS_DEBUG_JDWP.CURRENT_SESSION_SERIAL AS current_session_serial FROM gv$session WHERE inst_id = SYS_CONTEXT ('USERENV', 'INSTANCE') AND s..
SYS_ROW_ETAG 함수
·
Oracle/SQL
Oracle 23c에 SYS_ROW_ETAG 함수가 추가되었습니다. 이 함수는 칼럼 입력 순서와 무관하게 입력 값에 대한 고유한 32바이트 RAW 값을 반환합니다. 결과 값을 사용하면 데이터 변경 여부를 확인할 수 있습니다.SYS_ROW_ETAG (([[schema_name.]table_name.]column_name) [,([[schema_name.]table_name.]column_name)]...) 테스트를 위해 아래와 같이 테이블을 생성하겠습니다.-- 1DROP TABLE t1 PURGE;CREATE TABLE t1 (c1 NUMBER, c2 VARCHAR2(1), c3 VARCHAR2(1), c4 VARCHAR2(1));INSERT INTO t1 VALUES (1, 'A', 'A', 'B');I..
BITOR 함수와 BITXOR 함수
·
Oracle/SQL
Oracle 21c에 BITOR 함수와 BITXOR 함수가 추가되었습니다. 참고로 이 함수들은 문서화되지 않았습니다. 테스트를 위해 아래와 같이 테이블을 생성하겠습니다. -- 1 DROP TABLE t1 PURGE; CREATE TABLE t1 (c1 NUMBER, c2 NUMBER); INSERT INTO t1 VALUES (1, BIN_TO_NUM (0, 0, 1)); INSERT INTO t1 VALUES (2, BIN_TO_NUM (0, 1, 1)); INSERT INTO t1 VALUES (3, BIN_TO_NUM (1, 1, 1)); COMMIT; 아래는 BITOR 함수를 사용한 결과입니다. -- 2 SELECT c1, c2, BITOR (c2, 2) AS bo FROM t1; C1 C2 BO..