 
- SQL - Home
- SQL - Roadmap
- SQL - Overview
- SQL - RDBMS Concepts
- SQL - Databases
- SQL - Syntax
- SQL - Data Types
- SQL - Operators
- SQL - Expressions
- SQL - Comments
- SQL Database
- SQL - Create Database
- SQL - Drop Database
- SQL - Select Database
- SQL - Rename Database
- SQL - Show Databases
- SQL - Backup Database
- SQL Table
- SQL - Create Table
- SQL - Show Tables
- SQL - Rename Table
- SQL - Truncate Table
- SQL - Clone Tables
- SQL - Temporary Tables
- SQL - Alter Tables
- SQL - Drop Table
- SQL - Delete Table
- SQL - Constraints
- SQL Queries
- SQL - Insert Query
- SQL - Select Query
- SQL - Select Into
- SQL - Insert Into Select
- SQL - Update Query
- SQL - Delete Query
- SQL - Sorting Results
- SQL Views
- SQL - Create Views
- SQL - Update Views
- SQL - Drop Views
- SQL - Rename Views
- SQL Operators and Clauses
- SQL - Where Clause
- SQL - Top Clause
- SQL - Distinct Clause
- SQL - Order By Clause
- SQL - Group By Clause
- SQL - Having Clause
- SQL - AND & OR
- SQL - BOOLEAN (BIT) Operator
- SQL - LIKE Operator
- SQL - IN Operator
- SQL - ANY, ALL Operators
- SQL - EXISTS Operator
- SQL - CASE
- SQL - NOT Operator
- SQL - NOT EQUAL
- SQL - IS NULL
- SQL - IS NOT NULL
- SQL - NOT NULL
- SQL - BETWEEN Operator
- SQL - UNION Operator
- SQL - UNION vs UNION ALL
- SQL - INTERSECT Operator
- SQL - EXCEPT Operator
- SQL - Aliases
- SQL Joins
- SQL - Using Joins
- SQL - Inner Join
- SQL - Left Join
- SQL - Right Join
- SQL - Cross Join
- SQL - Full Join
- SQL - Self Join
- SQL - Delete Join
- SQL - Update Join
- SQL - Left Join vs Right Join
- SQL - Union vs Join
- SQL Keys
- SQL - Unique Key
- SQL - Primary Key
- SQL - Foreign Key
- SQL - Composite Key
- SQL - Alternate Key
- SQL Indexes
- SQL - Indexes
- SQL - Create Index
- SQL - Drop Index
- SQL - Show Indexes
- SQL - Unique Index
- SQL - Clustered Index
- SQL - Non-Clustered Index
- Advanced SQL
- SQL - Wildcards
- SQL - Injection
- SQL - Hosting
- SQL - Min & Max
- SQL - Null Functions
- SQL - Check Constraint
- SQL - Default Constraint
- SQL - Stored Procedures
- SQL - NULL Values
- SQL - Transactions
- SQL - Sub Queries
- SQL - Handling Duplicates
- SQL - Using Sequences
- SQL - Auto Increment
- SQL - Date & Time
- SQL - Cursors
- SQL - Common Table Expression
- SQL - Group By vs Order By
- SQL - IN vs EXISTS
- SQL - Database Tuning
- SQL Function Reference
- SQL - Date Functions
- SQL - String Functions
- SQL - Aggregate Functions
- SQL - Numeric Functions
- SQL - Text & Image Functions
- SQL - Statistical Functions
- SQL - Logical Functions
- SQL - Cursor Functions
- SQL - JSON Functions
- SQL - Conversion Functions
- SQL - Datatype Functions
- SQL Useful Resources
- SQL - Questions and Answers
- SQL - Cheatsheet
- SQL - Quick Guide
- SQL - Useful Functions
- SQL - Useful Resources
- SQL - Discussion
SQL - @@IDLE Function
The SQL @@IDLE statistical function is used to retrieve the idle time. It returns the total idle time that SQL server has been idle since it was last started(or began).
Note − If the time returned by the @@CPU_BUSY function exceeds the 49 days of cumulative CPU time, then you may get an arithmetic overflow warning.In that case, the value of @IDLE variables are accurate.
Syntax
Following is the syntax of the SQL @@IDLE function −
@@IDLE
Return type
The return type of this function is an INTEGER.
Parameters
- It does not accept any parameters. 
Return value
This function returns the total idle time of this SQL server.
Example
In the following example,we are using the SQL @@IDLE function to retrieve the total idle time of this SQL server since its last start.
SELECT @@IDLE AS Total_idle_time;
Output
Following is the output of the above query −
+-------------------+ | Total_idle_time | +-------------------+ | 241867257 | +-------------------+
Example
The following is another example of the SQL @@IDLE function. You can also use the GETDATE() function along with this function to retrieve the total idle time until today of this SQL server since it last began.
SELECT @@IDLE AS Total_idle_time, GETDATE() AS Curr_date;
Output
On executing the above program, it will produce the following output −
+-----------------+-------------------------+ | Total_idle_time | Curr_date | +-----------------+-------------------------+ | 241896780 | 2023-02-28 15:05:51.770 | +-----------------+-------------------------+
Example
In this example, we are using the SQL @@IDLE function to retrieve the total idle time of this SQL server, and we are using the CAST and @@TIMETICKS functions to print idle time in a microsecond.
SELECT @@IDLE AS Total_idle_time, GETDATE() AS Curr_date, @@IDLE *CAST(@@TIMETICKS AS float) AS Time_in_microsecond;
Output
The above SQL query produces the following output −
+-----------------+-------------------------+---------------------+ | Total_idle_time | Curr_date | Time_in_microsecond | +-----------------+-------------------------+---------------------+ | 242242169 | 2023-02-28 15:28:56.847 | 7570067781250 | +-----------------+-------------------------+---------------------+