Skip to main content

How to Add a Temporary Tablespace in Oracle Standalone Database

🧱 How to Add a Temporary Tablespace in Oracle Standalone Database

Temporary tablespaces in Oracle are used for sorting operations, managing global temporary tables, and handling intermediate result sets. It's a good practice to add or manage these tablespaces especially in large databases or when the default temp tablespace gets full or fragmented.

In this guide, we'll walk you through a clean and safe method to create a new temporary tablespace, make it default (if needed), and drop the old one (optional).


🔧 Step-by-Step Instructions

1️⃣ Connect to the Database as SYSDBA

sqlplus / as sysdba
-- or
sqlplus sys@ORCL as sysdba

2️⃣ Identify Existing Temporary Tablespaces

SELECT tablespace_name, status, contents 
FROM dba_tablespaces 
WHERE contents = 'TEMPORARY';

3️⃣ Create a New Temporary Tablespace

CREATE TEMPORARY TABLESPACE temp_new
TEMPFILE '/u01/app/oracle/oradata/ORCL/temp_new01.dbf'
SIZE 500M
AUTOEXTEND ON NEXT 100M MAXSIZE 5G
EXTENT MANAGEMENT LOCAL UNIFORM SIZE 1M;

💡 Tip: Adjust the TEMPFILE path and sizing parameters based on your filesystem and usage needs.

4️⃣ Make the New Temp Tablespace Default (Optional)

ALTER DATABASE DEFAULT TEMPORARY TABLESPACE temp_new;

5️⃣ Verify the Default Temporary Tablespace

SELECT property_name, property_value 
FROM database_properties 
WHERE property_name = 'DEFAULT_TEMP_TABLESPACE';

6️⃣ Drop the Old Temp Tablespace (Optional)

DROP TABLESPACE temp_old INCLUDING CONTENTS AND DATAFILES;

⚠️ Caution: Ensure the tablespace is no longer in use and is not the default before dropping it.


🧠 Why Manage Temporary Tablespaces?

  • Improve performance during large sorts and index creations.
  • Prevent "Temp Segment Full" errors by allocating enough space.
  • Enable better segregation for different types of workloads.

🚨 Best Practices

  • Always use EXTENT MANAGEMENT LOCAL and UNIFORM SIZE for better management.
  • Monitor temp usage with v$tempseg_usage and dba_temp_files.
  • Use AUTOEXTEND carefully to avoid unexpected filesystem usage spikes.

🎯 This process ensures your Oracle database handles temporary operations efficiently, helping prevent common space-related issues during sorts, joins, and global temp table operations.

Comments

Popular posts from this blog

🚀 Automating Oracle Database Patching with Ansible: A Complete Guide

Oracle database patching has long been the bane of DBAs everywhere. It's a critical task that requires precision, expertise, and often results in extended maintenance windows. What if I told you that you could automate this entire process, reducing both risk and downtime while ensuring consistency across your Oracle estate? 💡 In this comprehensive guide, I'll walk you through a production-ready Ansible playbook that completely automates Oracle patch application using OPatch. Whether you're managing a single Oracle instance or hundreds of databases across your enterprise, this solution will transform your patch management strategy! 🎯 🔥 The Challenge: Why Oracle Patching is Complex Before diving into the solution, let's understand why Oracle patching is so challenging: 🔗 Multiple dependencies : OPatch versions, Oracle Home configurations, running processes ⚠️ Risk of corruption : Incorrect patch application can render databases unusable ⏰ Downtime requirements : Da...

Oracle RAC Switchover & Switchback: Step-by-Step Guide

 Ensuring business continuity requires regular Disaster Recovery (DR) drills. This guide covers the Switchover and Switchback process between Primary (DC) and Standby (DR) databases . Pre-checks Before Performing Switchover Before starting the activity, ensure there are no active sessions in the database. If any are found, share the session details with the application team, get their confirmation, and terminate the sessions. Primary Database Name: PRIMARY Standby Database Name: STANDBY  Identify Active Sessions set lines 999 pages 999 col machine for a30 col username for a30 col program for a30 compute sum of count on report break on report select inst_id,username,osuser,machine,program,status,count(1) "count" from gv$session where inst_id=1 and program like 'JDBC%' group by inst_id,username,osuser,machine,program,status order by 1,2; select inst_id,username,osuser,machine,program,status,count(1) "count" from gv$session where inst_id=2 and program lik...

Mastering Oracle RAC with SRVCTL Commands

Oracle Real Application Clusters (RAC) provide high availability, scalability, and manageability for databases. One of the most powerful tools for managing RAC databases is srvctl , a command-line utility that allows administrators to control various database services. This blog explores essential srvctl commands to help you efficiently manage Oracle RAC environments. 1. Checking Database Configuration and Status  List all available databases on the host:                  srvctl config database   Check the status of a specific database and its instances:                    srvctl status database -d <database_name>   Retrieve detailed status information about a database, including its instances and states:                    srvctl status database -d <database_name> -v 2. Stopping and Starting Databases   ...