data:image/s3,"s3://crabby-images/6efd9/6efd9163d6c69a9fe99ab61df474dda28c65f858" alt=""
In-Memory Column Store
Unlike traditional row-based storage, The In-Memory Column Store (IM column store) stores tables and partitions in memory using a columnar format optimized for rapid scans. This columnar format is optimized for analytical workloads, allowing for efficient scanning of specific columns without reading entire rows.
In-Memory Optimized Dates
To enhance the performance of DATE-based queries DATE components (i.e. DAY, MONTH, YEAR) can be extracted and populated in the IM column store leveraging the In-Memory Expressions framework. This approach enables faster query processing on DATE columns, significantly improving the performance of date-based analytic queries.
Scenarios:
To explain the difference between using In-Memory Optimized Dates, I have prepared two scenarios:
- Scenario 1: Running a query without using In-Memory Optimized Dates
- Scenario 2: Running a query using In-Memory Optimized Dates
Prerequisites for these scenarios
Because the JOB_HISTORY table has a foreign key with another table, I cannot add several rows to it without the parent key, therefore, I created the JOB_HISTORY_INMEMORY table and added 10000 rows to it.
SQL> CREATE TABLE hr.job_history_inmemory AS SELECT * FROM hr.job_history; SQL> BEGIN FOR i IN 1..10000 LOOP INSERT INTO hr.job_history_inmemory (employee_id, start_date, end_date, job_id, department_id) VALUES (MOD(i, 200), SYSDATE - DBMS_RANDOM.VALUE(1, 1000), SYSDATE, 'IT_PROG', MOD(i, 10)); END LOOP; COMMIT; END; /
data:image/s3,"s3://crabby-images/82def/82def352157d30645c635504b57e3e1e7c8c6704" alt=""
Scenario 1: Running a query without using In-Memory Optimized Dates
SQL>SELECT employee_id, EXTRACT(MONTH FROM start_date) AS start_month, EXTRACT(YEAR FROM start_date) AS start_year FROM hr.job_history_inmemory WHERE EXTRACT(MONTH FROM start_date) = 5;
data:image/s3,"s3://crabby-images/38ee4/38ee4253368181ecbb5e6ef2ddf9f1d5a02d0c20" alt=""
Evaluating the plan shows that Oracle didn't use In-Memory Optimized Date.
data:image/s3,"s3://crabby-images/9c213/9c2132deed9020fd0467a41ef33ec23431d05336" alt=""
Scenario 2: Running a query using In-Memory Optimized Dates
The following conditions should be met to leverage the In-Memory Optimized Dates:
- Enabling the IM Column Store
To enable the IM Column Store, we should determine the size of the INMEMORY_SIZE parameter at the CDB level, shut down, and start the database.
SQL> ALTER SYSTEM SET INMEMORY_SIZE = 1G SCOPE=SPFILE;
data:image/s3,"s3://crabby-images/2ba70/2ba702427450d29df8c9fa6d46a28197b467fc8d" alt=""
Use the following query to find out if the In-Memory Column Store is enabled and its size.
data:image/s3,"s3://crabby-images/97bc4/97bc45f013d2a984e82dba4455915cdd7e63c14d" alt=""
Ensure the table is populated into the In-Memory Column Store:
Use the following command and check it using the query.
SQL> ALTER TABLE hr.job_history_inmemory INMEMORY; SQL> SELECT table_name, inmemory_size, inmemory_priority, inmemory_column_format FROM dba_inmemory_tables WHERE table_name = 'JOB_HISTORY_INMEMORY' AND owner = 'HR';
data:image/s3,"s3://crabby-images/cb78a/cb78a68de7acfb5de8ca371b68bf8804a732b41c" alt=""
Enabling INMEMORY_OPTIMIZED_DATE parameter
SQL>ALTER SYSTEM SET INMEMORY_OPTIMIZED_DATE = ENABLE SCOPE=MEMORY;
data:image/s3,"s3://crabby-images/edf99/edf99cd96a0d6cd847b43afe0cc75f88d7e30b9d" alt=""
Running the previous query and evaluating the plan:
SQL>SELECT employee_id, EXTRACT(MONTH FROM start_date) AS start_month, EXTRACT(YEAR FROM start_date) AS start_year FROM hr.job_history_inmemory WHERE EXTRACT(MONTH FROM start_date) = 5;
data:image/s3,"s3://crabby-images/c2edb/c2edb3fb549d8649d466767c38c3993be5401277" alt=""
The above plan shows that Oracle used In-Memory Optimized Date.