TRUNCATE

DDL

Removes all rows from a table quickly. Faster than DELETE but cannot be rolled back in some databases.

Syntax

TRUNCATE TABLE table_name [CASCADE]

Example

TRUNCATE TABLE logs;
TRUNCATE TABLE temp_data CASCADE;

About SQL TRUNCATE

The TRUNCATE keyword belongs to the DDL category of SQL statements. Removes all rows from a table quickly. Faster than DELETE but cannot be rolled back in some databases. Understanding this command is essential for any developer working with relational databases like PostgreSQL, MySQL, SQLite, or SQL Server.

SQL (Structured Query Language) is the standard language for managing and querying relational databases. The TRUNCATE statement is supported across all major database systems, though specific syntax may vary slightly between PostgreSQL, MySQL, MariaDB, Oracle, SQL Server, and SQLite. Always consult your database's documentation for vendor-specific features and limitations.

Best practices for using TRUNCATE: always test queries on a development database before running them in production, use parameterized queries to prevent SQL injection, and leverage EXPLAIN to understand query performance. For complex queries, consider using CTEs (Common Table Expressions) to improve readability and maintainability.

Related SQL Keywords