SQL queries are easily readable if they are in a standard SQL format; this can be achieved with the help of an online SQL formatting tool at:http://www.dpriver.com/pp/sqlformat.htm 
1. Following set of queries can be used to get various values from the database.
- Find all columns in a Database
SELECT SC.name AS ColumnName,
ST.name AS TableName
FROM sys.columns SC
INNER JOIN sys.tables S
ON ST.object_id
ORDER BY ST.name,
SC.name
ST.name AS TableName
FROM sys.columns SC
INNER JOIN sys.tables S
ON ST.object_id
ORDER BY ST.name,
SC.name
- List all the Functions in a Database
SELECT name AS function_name,
type_desc
FROM sys.objects
WHERE type_desc LIKE '%
- List all the Stored Procedures in a Database 
SELECT nameFROM sys.procedures
ORDER BY name
- List all the views in a Database
FROM sys.views
ORDER BY name
- List all the tables in a Database
SELECT name
FROM sys.tables
FROM sys.tables
- Find specific column and related table names
SELECT t.name AS table_name,SCHEMA_NAME(schema_id) AS schema_name,c.name AS column_name
FROM sys.tables AS t
INNER JOIN sys.columns c ON t.OBJECT_ID = c.OBJECT_ID
WHERE c.name LIKE '%column name%'ORDER BY schema_name, table_name
FROM sys.tables AS t
INNER JOIN sys.columns c ON t.OBJECT_ID = c.OBJECT_ID
WHERE c.name LIKE '%column name%'ORDER BY schema_name, table_name
- Data type of a column
SELECT
c.name 'Column Name',
t.Name 'Data type',
c.max_length 'Max Length',
c.precision ,
c.scale ,
c.is_nullable,
ISNULL(i.is_primary_key, 0) 'Primary Key'
FROM
sys.columns c
INNER JOIN
sys.types t ON c.system_type_id = t.system_type_id
LEFT OUTER JOIN
sys.index_columns ic ON ic.object_id = c.object_id AND ic.column_id = c.column_id
LEFT OUTER JOIN
sys.indexes i ON ic.object_id = i.object_id AND ic.index_id = i.index_id
WHERE
c.object_id = OBJECT_ID('YourTableName')
2. Queries to check if best practice is followed in SPs
SELECT routine_name,
routine_definition
FROM information_schema.rout
WHERE routine_definition LIKE
AND routine_type = '
routine_definition
FROM information_schema.rout
WHERE routine_definition LIKE
AND routine_type = '
Note: Verify for each combination, i.e., select*from, select *from, select* from.
- Query to identify if any SP uses IN or Not IN
SELECT routine_name,
routine_definition
FROM information_schema.rout
WHERE routine_definition LIKE
AND routine_type = '
routine_definition
FROM information_schema.rout
WHERE routine_definition LIKE
AND routine_type = '
SELECT routine_name,
routine_definition
FROM information_schema.rout
WHERE routine_definition LIKE
AND routine_type = '
routine_definition
FROM information_schema.rout
WHERE routine_definition LIKE
AND routine_type = '
Note: Verify for each combination of IN and Not IN, i.e., ‘IN(‘, ‘ IN (‘, ‘NotIN(‘, ‘Not IN(‘, ‘Not IN (‘.
- SP without initial comment
SELECT ROUTINE_NAME, ROUTINE_DEFINITIONFROM INFORMATION_SCHEMA.ROUTINESWHERE ROUTINE_DEFINITION not LIKE '%================%'AND ROUTINE_TYPE='PROCEDURE'
3. Following queries can be used to get performace details of the database
- CPU utilization in seconds
SELECT (total_worker_time * 1.0) / 1000000 AS CPU_Utilized_in_Seconds, text,*
FROM sys.dm_exec_query_stats
CROSS APPLY sys.dm_exec_sql_text(sql_
order by CPU_Utilized_in_Seconds desc
- To get longest running query, memory used & other details
SELECT Top 10 SUBSTRING(qt.TEXT, (qs.statement_start_offset/2)+
((CASE qs.statement_end_offset
WHEN -1 THEN DATALENGTH(qt.TEXT)
ELSE qs.statement_end_offset
END - qs.statement_start_offset)/2)+
qs.execution_count,
qs.total_logical_reads, qs.last_logical_reads,
qs.total_logical_writes, qs.last_logical_writes,
qs.total_worker_time,
qs.last_worker_time,
qs.total_elapsed_time/1000000 total_elapsed_time_in_S,
qs.last_elapsed_time/1000000 last_elapsed_time_in_S,
qs.last_execution_time,qp.quer
FROM sys.dm_exec_query_stats qs
CROSS APPLY sys.dm_exec_sql_text(qs.sql_
CROSS APPLY sys.dm_exec_query_plan(qs.plan
ORDER BY qs.total_logical_reads DESC
- Last query ran on SQL
SELECT deqs.last_execution_time AS [Time], dest.TEXT AS [Query]
FROM sys.dm_exec_query_stats AS deqs
CROSS APPLY sys.dm_exec_sql_text(deqs.sql_
ORDER BY deqs.last_execution_time DESC- Plan cache hit ratio
WITH cte1
AS (SELECT [dopc].[
[dopc].[
[dopc].[
[dopc].[cntr_
[dopc].[cntr_
Row_number()
OVER (
partition
ORDER BY [
FROM [sys].[dm_os_
WHERE [dopc].[
AND ( [dopc].[
OR [
AND [dopc].[
SELECT CONVERT(DECIMAL(16, 2),
                              
AS [hit_pct]
FROM [cte1] AS c
INNER JOIN [cte1] AS c1
ON c.[object_
AND c.[
WHERE [c].[r_n] = 1
AND [c1].[r_n] = 2;
AS (SELECT [dopc].[
[dopc].[
[dopc].[
[dopc].[cntr_
[dopc].[cntr_
Row_number()
OVER (
partition
ORDER BY [
FROM [sys].[dm_os_
WHERE [dopc].[
AND ( [dopc].[
OR [
AND [dopc].[
SELECT CONVERT(DECIMAL(16, 2),
AS [hit_pct]
FROM [cte1] AS c
INNER JOIN [cte1] AS c1
ON c.[object_
AND c.[
WHERE [c].[r_n] = 1
AND [c1].[r_n] = 2;
- Plan cache reuse
DECLARE @single DECIMAL(18, 2)
DECLARE @reused DECIMAL(18, 2)
DECLARE @total DECIMAL(18, 2)
SELECT @single = Sum(CASE ( us
WHEN 1
ELSE 0
END) * 1.
@reused = Sum(CASE ( us
WHEN 1
ELSE 1
END) * 1.
@total = Count(
FROM sys.dm_exec_cached_
SELECT ( @single / @total ) *
DECLARE @reused DECIMAL(18, 2)
DECLARE @total DECIMAL(18, 2)
SELECT @single = Sum(CASE ( us
WHEN 1
ELSE 0
END) * 1.
@reused = Sum(CASE ( us
WHEN 1
ELSE 1
END) * 1.
@total = Count(
FROM sys.dm_exec_cached_
SELECT ( @single / @total ) *
- Identify if a column is reaching limit of the datatype
WITH cte_1
AS (SELECT Object_name(a.
a.name AS colu
CONVERT(BIGINT
CASE
WHEN b.name
WHEN b.name
WHEN b.name
WHEN b.name
END AS dt_
FROM sys.identity_
INNER JOIN sys
ON a.s
cte_2
AS (SELECT *,
CONVERT(NUMERI
                              
AS 'Percent'
FROM cte_1)
SELECT *
FROM cte_2
ORDER BY 'Percent' DESC;
AS (SELECT Object_name(a.
a.name AS colu
CONVERT(BIGINT
CASE
WHEN b.name
WHEN b.name
WHEN b.name
WHEN b.name
END AS dt_
FROM sys.identity_
INNER JOIN sys
ON a.s
cte_2
AS (SELECT *,
CONVERT(NUMERI
AS 'Percent'
FROM cte_1)
SELECT *
FROM cte_2
ORDER BY 'Percent' DESC;
- Number of unused indexes
SELECT db_name() as dbname,
       o.name as tablename,
       i.name as indexname,
       i.index_id,
       user_seeks + user_scans + user_lookups as total_reads,
       user_updates as total_writes,
       (SELECT SUM(p.rows)
          FROM sys.partitions p
         WHERE p.index_id = s.index_id
           AND s.object_id = p.object_id) as number_of_rows,
       s.last_user_lookup,
       s.last_user_scan,
       s.last_user_seek
  FROM sys.indexes i
 INNER JOIN sys.objects o
    ON i.object_id = o.object_id
  LEFT OUTER JOIN sys.dm_db_index_usage_stats s
    ON i.index_id = s.index_id
   AND s.object_id = i.object_id
 WHERE OBJECTPROPERTY(o.object_id, 'IsUserTable') = 1
   AND ISNULL(s.database_id, DB_ID()) = DB_ID()
   AND (
        isnull(s.last_user_seek, '19000101') < datediff(month, -1, getdate()) AND
        isnull(s.last_user_scan, '19000101') < datediff(month, -1, getdate()) AND
        isnull(s.last_user_lookup, '19000101') < datediff(month, -1, getdate())
       )
 ORDER BY total_reads DESC; - Tables without clustered indexes defined
| 
WITH CTE_1 | |
| 
AS | |
| 
( | |
| 
  SELECT db_name() as dbname, | |
| 
         (SELECT SUM(p.rows) | |
| 
            FROM sys.partitions p | |
| 
           WHERE p.index_id = i.index_id | |
| 
             AND i.object_id = p.object_id) as number_of_rows | |
| 
    FROM sys.indexes i | |
| 
   INNER JOIN sys.objects o | |
| 
      ON i.object_id = o.object_id | |
| 
   WHERE OBJECTPROPERTY(o.object_id, 'IsUserTable') = 1 | |
| 
     AND OBJECTPROPERTY(o.object_id, 'TableHasClustIndex') = 0 | |
| 
) | |
| 
SELECT * | |
| 
  FROM CTE_1 | |
| 
 WHERE number_of_rows > 1000; | |
- Possible duplicate indexes
WITH indexcolsAS (SELECT object_id AS id,index_id AS indid,name,(SELECT CASE keynoWHEN 0 THEN NULLELSE colidEND AS [data()]FROM sys.sysindexkeys AS kWHERE k.id = i.object_idAND k.indid = i.index_idORDER BY keyno,colidFORXML PATH('')) AS cols,(SELECT CASE keynoWHEN 0 THEN colidELSE NULLEND AS [data()]FROM sys.sysindexkeys AS kWHERE k.id = i.object_idAND k.indid = i.index_idORDER BY colidFORXML PATH('')) AS incFROM sys.indexes AS i)SELECT DB_NAME() AS 'DBName',OBJECT_SCHEMA_NAME(c1.id) + '.'+ OBJECT_NAME(c1.id) AS 'TableName',c1.name + CASE c1.indidWHEN 1 THEN ' (clustered index)'ELSE ' (nonclustered index)'END AS 'IndexName',c2.name + CASE c2.indidWHEN 1 THEN ' (clustered index)'ELSE ' (nonclustered index)'END AS 'ExactDuplicatedIndexName'FROM indexcols AS c1INNER JOIN indexcols AS c2ONc1.id = c2.idAND c1.indid < c2.indidAND c1.cols = c2.colsAND c1.inc = c2.inc;
- Performance related database settings
DECLARE @Result INT; DECLARE @High INT; -- For settings you feel need to be righ DECLARE @Med INT; -- For settings you want to know about but arent critical DECLARE @Low INT; -- For settings that you want flagged but are low importance SELECT @High = 70, @Med = 40, @Low = 10; SELECT @Result = SUM(CASE WHEN [d].[compatibility_level] != [d2].[compatibility_level] THEN @Med ELSE 0 END + CASE WHEN [d].[collation_name] != [d2].[collation_name] THEN @Med ELSE 0 END + CASE WHEN [d].[user_access] != 0 THEN @Low ELSE 0 END + CASE WHEN [d].[is_auto_close_on] = 1 THEN @High ELSE 0 END + CASE WHEN [d].[is_auto_shrink_on] = 1 THEN @High ELSE 0 END + CASE WHEN [d].[state] != 0 THEN @Low ELSE 0 END + CASE WHEN [d].[is_auto_create_stats_on] != 1 THEN @Med ELSE 0 END + CASE WHEN [d].[is_auto_update_stats_on] != 1 THEN @Med ELSE 0 END + CASE WHEN [d].[is_ansi_nulls_on] = 1 THEN @High ELSE 0 END + CASE WHEN [d].[is_ansi_padding_on] = 1 THEN @High ELSE 0 END + CASE WHEN [d].[is_ansi_warnings_on] = 1 THEN @High ELSE 0 END + CASE WHEN [d].[is_arithabort_on] = 1 THEN @High ELSE 0 END) FROM [sys].[databases] AS d CROSS JOIN [sys].[databases] AS d2 WHERE [d2].[name] = 'master' AND ([d].[database_id] = DB_ID() AND [d].[state_desc] = 'Online'); SELECT @Result;Happy Coding!!
