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..
JSON Relational Duality #3 - M:1 조인 Duality 뷰
·
Oracle/JSON
JSON Relational Duality #1 - 단순 Duality 뷰 JSON Relational Duality #2 - 1:M 조인 Duality 뷰 JSON Relational Duality #3 - M:1 조인 Duality 뷰 지난 글에 이어 이번 글에서는 M:1 조인 Duality 뷰의 동작에 대해 살펴보겠습니다. 준비테스트 버전은 아래와 같습니다.-- 1SELECT version_full FROM product_component_version;VERSION_FULL------------23.4.0.24.051 row selected. 테스트를 위해 아래와 같이 테이블을 생성하겠습니다.DROP TABLE t1 PURGE;DROP TABLE t2 PURGE;CREATE TABLE t1 (c1..
JSON Relational Duality #2 - 1:M 조인 Duality 뷰
·
Oracle/JSON
JSON Relational Duality #1 - 단순 Duality 뷰 JSON Relational Duality #2 - 1:M 조인 Duality 뷰 JSON Relational Duality #3 - M:1 조인 Duality 뷰 지난 글에 이어 이번 글에서는 1:M 조인 Duality 뷰의 동작에 대해 살펴보겠습니다. 준비테스트 버전은 아래와 같습니다.-- 1SELECT version_full FROM product_component_version;VERSION_FULL------------23.4.0.24.051 row selected. 테스트를 위해 아래와 같이 테이블을 생성하겠습니다.-- 2DROP TABLE t1 PURGE;DROP TABLE t2 PURGE;CREATE TABLE t1..
JSON Relational Duality #1 - 단순 Duality 뷰
·
Oracle/JSON
JSON Relational Duality #1 - 단순 Duality 뷰JSON Relational Duality #2 - 1:M 조인 Duality 뷰JSON Relational Duality #3 - M:1 조인 Duality 뷰 Oracle 23ai에 JSON Relational Duality 기능이 추가되었습니다. 이 기능을 사용하면 JSON-Relational Duality 뷰(이후 Duality 뷰)를 통해 RDB 모델을 JSON 문서로 조회하거나 변경할 수 있습니다. 이 글에서는 조인이 없는 단순 뷰의 동작에 대해 살펴보겠습니다. JSON Relational Duality에 대한 상세한 내용은 JSON-Relational Duality Developer's Guide를 참고하세요. 준비테스..