title | description | author | ms.author | ms.reviewer | ms.date | ms.service | ms.subservice | ms.topic | f1_keywords | helpviewer_keywords | dev_langs | |||||||||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
SSMS Query Editor |
SQL Server Management Studio (SSMS) Query Editor |
markingmyname |
maghan |
randolphwest |
11/16/2023 |
sql |
ssms |
ui-reference |
|
|
|
[!INCLUDE SQL Server ASDB, ASDBMI, ASDW]
This article explains the query editor's features and functions in SQL Server Management Studio (SSMS).
Note
If you want to learn how to use Transact-SQL (T-SQL) F1 Help, please view the Transact-SQL F1 Help section.
If you want to learn about tasks that you can do with the editor, please visit the Editor tasks section.
The editors in SSMS share a typical architecture. The text editor implements the base level of functionality and can be used as a basic editor for text files. The other editors, or query editors, extend this functionality base by including a language service that defines the syntax of one of the languages supported in SQL Server. The query editors also implement varying levels of support for editor features such as IntelliSense and debugging. The query editors include the Database Engine Query Editor for use in building scripts containing T-SQL and XQuery statements, the MDX editor for the MDX language, the DMX editor for the DMX language, and the XML/A editor for the XML for Analysis language. You can use the Query Editor to create and run scripts containing Transact-SQL statements.
:::image type="content" source="media/database-engine-query-editor-sql-server-management-studio/new-query.png" alt-text="Screenshot of New query.":::
When the Query Editor is open, the SQL Editor toolbar appears with the following buttons.
You can also add the SQL Editor toolbar by selecting the View menu, selecting Toolbars, and then selecting SQL Editor. If you add the SQL Editor toolbar when no Query Editor windows are open, all the buttons are unavailable.
:::image type="content" source="media/database-engine-query-editor-sql-server-management-studio/editor-toolbar.png" alt-text="Screenshot of Editor toolbar.":::
Opens the Connect to Server dialog box. Use this dialog box to establish a connection to a server.
You can also connect to your database using the context menu.
Opens the Connect to Server dialog box. Use this dialog box to establish a connection to a different server.
You can also change connections using the context menu.
Change the connection to a different database on the same server.
Executes the selected code or, if no code is selected, it executes all the Query Editor code.
You can also Execute a query by selecting F5 or from the context menu.
Sends a cancellation request to the server. Some queries can't be canceled immediately but must wait for a suitable cancellation condition. When transactions are canceled, delays might occur while transactions are rolled back.
You can also cancel an executing query by selecting Alt + Break.
Checks the syntax of the selected code. If no code is selected, it checks all the code's syntax in the Query Editor window.
You can also check the code in the Query Editor by selecting Ctrl + F5.
Requests a query execution plan from the query processor without executing the query, and displays the plan in the Execution plan window. This plan uses index statistics to estimate the number of rows expected to return during each part of the query execution. The actual query plan that is used can be different from the estimated execution plan. If the number of returned rows is different from the estimate, and the query processor changes the plan to be more efficient, this can occur.
You can also display an estimated execution plan by selecting Ctrl + L or from the context menu.
Opens the Query Options dialog box. Use this dialog box to configure the default options for query execution and for query results.
You can also select Query Options from the context menu.
Specifies whether IntelliSense functionality is available in the Database Engine Query Editor. This option is set by default.
You can also select IntelliSense Enabled by selecting Ctrl + B then Ctrl + I, or from the context menu.
Executes the query, returns the query results, and uses the execution plan for the query. The queries appear as a graphical query plan in the Execution plan window.
You can also select the Include Actual Execution Plan by selecting Ctrl + M or from the context menu.
Provides real-time insights into the query execution process as the controls flow from one query plan operator to another.
You can also select the Include Live Query Statistics from the context menu.
Includes a Client Statistics window that contains statistics about the query and about the network packets, and the elapsed time of the query.
You can also select the Include Live Query Statistics by selecting Shift + Alt + S or from the context menu.
Returns the query results as text in the Results window.
You can also return results to text by selecting Ctrl + T or from the context menu.
Returns the query results as one or more grids in the Results window. This option is enabled by default.
You can also return results to text by selecting Ctrl + D or from the context menu.
When the query executes, the Save Results dialog box opens. In Save In, select the folder in which you want to save the file. In Filename, type the name of the file, and then select Save to save the query results as a Report file that has the .rpt extension. For advanced options, select the down-arrow on the Save button, and then select Save with Encoding.
You can also return results to text by selecting Ctrl + Shift + F or from the context menu.
Makes the current line a comment by adding a comment operator (--) at the beginning of the line.
You can also comment out a line by selecting Ctrl + K, then Ctrl + C.
Makes the current line an active source statement by removing any comment operator (--) at the beginning of the line.
You can also uncomment a line by selecting Ctrl + K, then Ctrl + U.
Moves the text of the line to the left by removing blanks at the beginning of the line.
Moves the text of the line to the right by adding blanks at the beginning of the line.
Opens a dialog box that you can use to specify values for parameters in stored procedures and functions.
You can access the context menu by right-clicking anywhere in the query editor. The options in the context menu are similar to the SQL Editor Toolbar. With the context menu, you see the same options as Connect and Execute, but you also get other options listed, such as Insert Snippet and Surround With.
:::image type="content" source="media/database-engine-query-editor-sql-server-management-studio/context-menu.png" alt-text="Screenshot of Options.":::
Transact-SQL Snippets are templates you can use as a starting point when writing new Transact-SQL statements in the Query Editor.
A surround-with snippet is a template you can use as a starting point when enclosing a set of Transact-SQL statements in a BEGIN, IF, or WHILE block.
:::image type="content" source="media/database-engine-query-editor-sql-server-management-studio/context-menu-connections.png" alt-text="Screenshot of Connections available.":::
There are more Connection options in the context menu compared to the toolbar options in SSMS.
-
Connect - Opens the Connect to Server dialog box. Use this dialog box to establish a connection to a server.
-
Disconnect - Disconnects the current Query Editor from the server.
-
Disconnect All Queries - Disconnects all query connections.
-
Change Connection - Opens the Connect to Server dialog box. Use this dialog box to establish a connection to a different server.
Object Explorer provides a hierarchical user interface to view and manage the objects in each instance of SQL Server. The Object Explorer Details pane presents a tabular view of instance objects, and the capability to search for specific objects. The capabilities of Object Explorer vary slightly depending on the type of server, but generally include the development features for databases, and management features for all server types.
Executes the selected code or, if no code is selected, executes all the code in the Query Editor.
Requests a query execution plan from the query processor without actually executing the query, and displays the plan in the Execution plan window. This plan uses index statistics to estimate the number of rows expected to return during each part of the query execution. The actual query plan that is used can be different from the estimated execution plan. If the number of rows that are returned is different from the estimate, and the query processor changes the plan to be more efficient, this can occur.
Specifies whether IntelliSense functionality is available in the Database Engine Query Editor. This option is set by default.
SQL Server Profiler is an interface to create and manage traces and analyze and replay trace results. Events are saved in a trace file that can later be analyzed or used to replay a specific series of steps when trying to diagnose a problem.
The Microsoft Database Engine Tuning Advisor (DTA) analyzes databases and makes recommendations that you use to optimize query performance. You use the Database Engine Tuning Advisor to select and create an optimal set of indexes, indexed views, or table partitions without having an expert understanding of the database structure or the internals of SQL Server. Using the DTA, you can perform the following tasks.
The Query and View Designer opens when you open the definition of a view, show the results for a query or view, or create or open a query.
Executes the query, returns the query results, and uses the execution plan for the query. The queries appear as a graphical query plan in the Execution plan window.
Provides real-time insights into the query execution process as the controls flow from one query plan operator to another.
Includes a Client Statistics window that contains statistics about the query and about the network packets, and the elapsed time of the query.
:::image type="content" source="media/database-engine-query-editor-sql-server-management-studio/context-menu-results.png" alt-text="Screenshot of Results options.":::
You can select any of the Result options you want from the context menu.
-
Results to Text - Returns the query results as text in the Results window.
-
Results to Grid - Returns the query results as one or more grids in the Results window.
-
Results to File - When the query executes, the Save Results dialog box opens. In Save In, select the folder in which you want to save the file. In File name, type the file's name, and then select Save to save the query results as a Report file with the .rpt extension. For advanced options, select the down-arrow on the Save button, and then select Save with Encoding.
The Properties window describes the state of an item in SQL Server Management Studio, such as a connection or a Showplan operator, and information about database objects such as tables, views, and designers.
You use the Properties window to view the properties of the current connection. Many properties are read-only in the Properties window but can be changed elsewhere in the Management Studio. For example, the Database property of a query is read-only in the Properties window but can be changed on the tool bar.
Opens the Query Options dialog box. Use this dialog box to configure the default options for query execution and query results.
The Query Editor supports linking you to the reference article for a specific Transact-SQL statement when you select F1. To do so, highlight the name of a Transact-SQL statement and then select F1. The help search engine then searches for an article that has an F1 help attribute that matches the string you highlighted.
If the help search engine doesn't find an article with an F1 help keyword that exactly matches the string you highlighted, then this article is displayed. In that case, there are two approaches to finding the help you're looking for:
-
Copy and paste the editor string you highlighted into the search tab of SQL Server Books Online and do a search.
-
Highlight only the part of the Transact-SQL statement likely to match an F1 help keyword applied to an article and select F1 again. The search engine requires an exact match between the string you highlighted and an F1 help keyword assigned to an article. If the string you highlighted contains elements unique to your environment, such as column or parameter names, the search engine doesn't get a match. Examples of the strings to highlight include:
-
The name of a Transact-SQL statement, such as
SELECT
,CREATE DATABASE
, orBEGIN TRANSACTION
. -
The name of a built-in function, such as
SERVERPROPERTY
, or@@VERSION
. -
The name of a system stored procedure table, or views, such as
sys.data_spaces
orsp_tableoption
.
-
Task Description | Article |
---|---|
Describes the various ways you can open the editors in SSMS. | Open an Editor (SQL Server Management Studio) |
Configure options for the various editors, such as line numbering and IntelliSense options. | Configure Editors (SQL Server Management Studio) |
How to manage the view mode, such as word wrap, splitting a window, or tabs. | Manage the Editor and View Mode |
Set formatting options, such as hidden text or indentation. | Manage Code Formatting |
Navigate through the text in an editor window by using features such as incremental search or go to. | Navigate Code and Text |
Set color coding options for various classes of syntax, which makes it easier to read complex statements. | Color Coding in Query Editors |
Drag text from one location in a script and drop it in a new location. | Drag and Drop Text |
How to set bookmarks in order to more easily find important pieces of code. | Manage Bookmarks |
How to print scripts or the results in a window or grid. | Print Code and Results |
View and use the basic features in the MDX Query Editor. | Create Analysis Services Scripts |
View and use the basic features in the DMX Query Editor. | Create a DMX Query |
View and use the basic features in the XML/A Editor. | XML Editor (SQL Server Management Studio) |
How to use the sqlcmd features in the Database Engine Query Editor. | Edit SQLCMD Scripts with Query Editor |
How to use code snippets in the Database Engine Query Editor. Snippets are templates for commonly used statements or blocks, and can be customized or extended to include site-specific snippets. | Add Transact-SQL Snippets |
How to use the Transact-SQL debugger to step through code and view debugging information such as the values in variables and parameters. | Transact-SQL debugger |