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---..
Hybrid Vector Index
·
Oracle/Vector
Oracle 23ai(23.6)에 하이브리드 벡터 인덱스 기능이 추가되었습니다. 하이브리드 벡터 인덱스를 사용하하면 전체 텍스트 검색(full-text search)과 벡터 유사도 검색(vector similarity search)을 조합하여 데이터를 조회할 수 있습니다. 테스트를 위해 예제 데이터를 다운로드하고 아래와 같이 압축을 해제하겠습니다.$ unzip /home/oracle/wiki/vector_database_wikipedia_articles_embedded.zipArchive: vector_database_wikipedia_articles_embedded.zip inflating: vector_database_wikipedia_articles_embedded.csv inflating: ..
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 ] [ ..
Materialized Expression Columns
·
Oracle/Administration
Oracle 23ai(23.7)에 Materialized Expression Columns 기능이 추가되었습니다. Materialized Expression Column은 물리적으로 값이 저장되는 Virtual Column입니다. 기능이 추가되면서 Virtual Column을 Expression Column으로 명칭을 변경하고 기존의 Virtual Column을 Virtual Expression Column, 추가된 기능을 Materialized Expression Column으로 명명한 것으로 보입니다. 아래는 virtual_column_definition 절의 구문입니다. 칼럼 표현식 뒤에 VIRTUAL 또는 MATERIALIZED 키워드를 사용할 수 있습니다.column [datatype] [ VI..
Relational Data Vectorization
·
Oracle/Vector
Oracle 23ai(23.6)에 Relational Data Vectorization 기능이 추가되었습니다. 이 기능을 사용하면 관계형 데이터로 벡터를 생성할 수 있습니다. 테스트를 위해 Bank Marketing 데이터를 다운로드하여 아래와 같이 압축을 해제하겠습니다. bank-additional-full.csv 파일의 로우 수는 41,189 건입니다.$ unzip bank+marketing.zip$ unzip bank-additional.zip$ cd bank-additional$ wc -l bank-additional-full.csv41189 bank-additional-full.csv 아래와 같이 External 테이블를 사용하여 bank-additional-full.csv 파일을 bank 테이..
Dynamic Statistics for PL/SQL Functions
·
Oracle/Performance
개요Oracle 23ai(23.8)에 Dynamic Statistics for PL/SQL Functions 기능이 추가되었습니다. 이 기능은 PL/SQL 함수에 대한 동적 통계를 수집합니다. 이 글에서는 스칼라 타입을 반환하는 PL/SQL 함수를 스칼라 함수, 컬렉션 타입을 반환하는 PL/SQL 함수를 테이블 함수로 지칭합니다. plsql_function_dynamic_stats 파라미터로 PL/SQL 함수에 대한 동적 통계 수집의 동작을 설정할 수 있습니다. 기본값은 PREFERENCE로 dynamic_stats 설정에 따라 동적 통계를 수집합니다.-- 1-1SELECT name, value, isses_modifiable, issys_modifiable FROM v$parameter WHERE n..
DBMS_SQLDIAG.REPORT_SQL 함수
·
Oracle/Performance
Oracle 23ai에 DBMS_SQLDIAG.REPORT_SQL 함수가 추가되었습니다. 이 함수는 SQL 문에 대한 정보를 포함한 리포트를 HTML 형식을 반환합니다. DBMS_SQLDIAG.REPORT_SQL 함수의 정의는 아래와 같습니다. directory에 값을 입력하면 디렉토리에 SQLR__.html 형식의 파일이 생성됩니다.DBMS_SQLDIAG.REPORT_SQL ( sql_id IN VARCHAR2 , directory IN VARCHAR2 DEFAULT NULL , level IN VARCHAR2 DEFAULT 'TYPICAL' -- BASIC, TYPICAL, ALL) RETURN CLOB; 테스트를 위해 아래와 같이 테이블과 인덱스를 생성하겠습니다.-- 1D..
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-------- ----- -----------..
ONNX Model
·
Oracle/Vector
Oracle 23ai부터 DBMS_VECTOR 패키지로 ONNX 모델을 데이터베이스에 로드할 수 있습니다. 테스트를 위해 all-MiniLM-L12-v2 ONNX 모델를 다운로드하고 압축을 해제하겠습니다.$ unzip /home/oracle/onnx/all_MiniLM_L12_v2_augmented.zipArchive: all_MiniLM_L12_v2_augmented.zip inflating: all_MiniLM_L12_v2.onnx inflating: README-ALL_MINILM_L12_V2-augmented.txt 아래와 같이 디렉토리를 생성하고 DBMS_VECTOR.LOAD_ONNX_MODEL 프로시저를 사용하여 all-MiniLM-L12-v2 ONNX 모델을 데이터베이스에 로드하겠습니다..
Staging Table
·
Oracle/Administration
Oracle 23ai에 Staging Table 기능이 추가되었습니다. 적재 성능을 개선하기 위해 로깅 최소화 등의 기능이 추가되기를 바랬지만 현재까지는 압축, 통계 수집, 파티션 관리가 불가능하고 삭제시 즉시 PURGE되는 점을 제외하면 일반 테이블과 크게 다르지 않은 것 같습니다.Staging tables are heap tables optimized for fast data ingestion and for handling volatile data. Key table attributes are set to defaults for these use cases without any additional user interaction. Creating staging tables rather than 'nor..