|   
 MSSQL extension for Visual Studio CodeThe MSSQL Extension for Visual Studio Code is designed to empower developers by providing a seamless and modern database development experience. Our goal is to make SQL development more productive and intuitive by integrating essential features such as schema management, query execution, and AI-powered assistance. Explore and Learn
 General Availability Features
Connect to your databases: Seamlessly manage your database connections
Connect to SQL database in Fabric, Azure SQL, and SQL Server using a user-friendly interfaceUse an intuitive Connection Dialog to enter parameters, paste a connection string, or browse Azure resourcesAccess recent connections quickly from a dedicated panelUse Microsoft Entra ID authentication for secure accessManage multiple connection profiles for different environmentsReconnect to frequently used databases in just a few clicksOrganize your connections into color-coded groups to manage local, staging, and production environments side by side.Execute queries and View Results: Run your scripts and view results in a simple, yet powerful, grid with improved data visualization features:
View results in a unified interface alongside the integrated terminal and output panels or in their own tab.Sort results by clicking on column headers.Easily copy results with or without headers for use in other applications.Export results to multiple formats, including JSON, Excel, and CSV.Enhanced experience with live execution timing summary metrics and stability improvements on large result setsView estimated plan and actual plan for T-SQL queries.Enhanced T-SQL Editing Experience: Write T-SQL scripts with a range of powerful features, including:
IntelliSense for faster and more accurate coding.Go to Definition for exploring database objects.T-SQL snippets to speed up repetitive tasks.Syntax colorizations and T-SQL error validations.Support for the GObatch separator.Object Explorer: Navigate and manage your database structure with ease
Browse databases, tables, views, and programmability objectsExpand or collapse objects to explore hierarchy visuallyUse enhanced filters to quickly locate items by name, owner, or creation dateStreamline development in large databases with fast object accessTable Designer: A visual tool for creating and managing tables in your databases. Design every aspect of the table's structure, including:
Adding columns, setting data types, and specifying default values.Defining primary keys and managing indexes to improve query performance.Setting up foreign keys to maintain data integrity across tables.Configuring advanced options like check constraints.Automatically generate T-SQL scripts for your table design and apply changes directly to the database.Query Plan Visualizer: Analyze SQL query performance with detailed execution plans. Key features include:
Interact with each step in the execution plan, including collapsing or expanding nodes for a simplified view.Zoom in or out to adjust the level of detail, or use "zoom to fit" for a complete view of the plan.Highlight key performance indicators, such as elapsed time or subtree cost, to identify bottlenecks in query execution.Local SQL Server Containers
Create and manage SQL Server containers locally without Docker commandsUse SQL Server 2025 by default with vector and AI-ready featuresAuto-connect with a ready-to-use connection profileStart, stop, restart, or delete containers from the connection panelAutomatic port conflict detection and resolutionCustomize container name, hostname, port, and versionSchema Designer: Visual schema modeling and editing—code-free
Design, view, and manage database schemas using an intuitive drag-and-drop GUIAdd or modify tables, columns, primary keys, and foreign key relationships without writing T-SQLPreview schema changes instantly as read-only T-SQL in the built-in code paneNavigate large schemas easily with search, mini-map, zoom, and auto-layoutFilter by table name or relationship to focus on specific areas of your schemaExport diagrams to share with your team or include in documentationPush updates to your database using the built-in deploymentSchema Compare: Effortless schema synchronization and management
Compare schemas between two databases, DACPAC files, or SQL projects and see additions, removals, and modifications at a glanceFilter and exclude specific differences before syncingApply changes directly or generate a deployment script for later useSave comparisons to rerun or audit schema changesCustomizable Extension Options: Configure command shortcuts, appearance, and other settings to personalize your development experience. Public Preview Features
GitHub Copilot Integration (Preview): Boost your productivity with AI‑assisted SQL development
Intelligent T‑SQL completions and natural‑language promptsExplain objects and generate schema or test dataIdentify risky patterns and improve SQL security practicesGitHub Copilot Agent Mode (Preview) Let Copilot perform database tasks on your behalf
Securely executes actions like connecting, switching databases, or running queries directly from chatSurfaces schema details and connection info without manual navigationProvides a confirmable, AI-driven assistant for common database workflowsAccess all approved Agent tools from the Tools panelGitHub Copilot Slash Commands (Preview): Quick, discoverable shortcuts in chat
Type /to see commands like/connect,/changeDatabase,/runQuery,/explain,/fix,/optimizeConnection commands open the MSSQL connection panel; query commands accept input and return results in chatFabric Integration (Preview): Browse workspaces and provision SQL databases in Fabric directly from VS Code
Sign in with Microsoft Entra ID, browse workspaces, search, and connect to SQL databases or SQL analytics endpoints from the Connection dialog (includes Open in MSSQL from the Fabric extension)Create a SQL database from the Deployments page; capacity‑aware and auto‑connects when complete 
 ResourcesUsing the MSSQL ExtensionFollow these steps to get started with the MSSQL extension: 
Install Visual Studio Code and then install the MSSQL extension from the Extensions view or via the command palette (F1, then typeInstall Extensions).macOS users: Install OpenSSL. See the DotNet Core instructions for prerequisites.Open or create a .sqlfile. To manually set language mode, pressCtrl+K Mand select SQL.Press F1, typeMS SQL: Manage Connection Profile, and follow the prompts to create a profile. See manage connection profiles for advanced options.Connect to a database using F1>MS SQL: Connector the shortcutCtrl+Shift+C.Write your T-SQL script using IntelliSense and snippets. Type sqlto explore available snippets.Run queries by selecting MS SQL: Execute Query from the Command Palette (F1), or use the shortcut: 
Windows/Linux: Ctrl+Shift+EmacOS: Cmd+Shift+E 
Customize shortcuts via the command palette or in your settings.json. See customize shortcuts for help. Command Palette CommandsThe extension provides several commands in the Command Palette for working with .sqlfiles. Here are some of the most commonly used commands: 
MS SQL: Connect to SQL Server, Azure SQL Database or SQL Data Warehouse using connection profiles or recent connections.
Create Connection Profile to create a new connection profile and connect.MS SQL: Disconnect from SQL Server, Azure SQL Database or SQL Data Warehouse in the editor session.MS SQL: Use Database to switch the database connection to another database within the same connected server in the editor session.MS SQL: Execute Query script, T-SQL statements or batches in the editor.MS SQL: Cancel Query execution in progress in the editor session.MS SQL: Manage Connection Profiles
Create a new connection profile using command palette's step-by-step UI guide.Edit user settings file (settings.json) in the editor to manually create, edit or remove connection profiles.Remove an existing connection profile using command palette's step-by-step UI guide.Clear Recent Connection List to clear the history of recent connections. Extension SettingsThe following Visual Studio Code settings are available for the mssql extension. These can be set in user preferences (cmd+,) or workspace settings (.vscode/settings.json). // General Settings
{
  "mssql.maxRecentConnections": 5,
  "mssql.enableRichExperiences": true,
  "mssql.openQueryResultsInTabByDefault": false,
  "mssql.logDebugInfo": false,
  "mssql.messagesDefaultOpen": true,
  "mssql.connectionManagement.rememberPasswordsUntilRestart": true
}
// IntelliSense
{
  "mssql.intelliSense.enableIntelliSense": true,
  "mssql.intelliSense.enableErrorChecking": true,
  "mssql.intelliSense.enableSuggestions": true,
  "mssql.intelliSense.enableQuickInfo": true,
  "mssql.intelliSense.lowerCaseSuggestions": false
}
// Results and Grid
{
  "mssql.resultsFontFamily": null,
  "mssql.resultsFontSize": null,
  "mssql.copyIncludeHeaders": false,
  "mssql.copyRemoveNewLine": true,
  "mssql.saveAsCsv.includeHeaders": true,
  "mssql.saveAsCsv.delimiter": ",",    // Options: ",", "\t", ";", "|"
  "mssql.saveAsCsv.lineSeparator": null,
  "mssql.saveAsCsv.textIdentifier": "\"",
  "mssql.saveAsCsv.encoding": "utf-8", // Options: "utf-8", "utf-16le", "utf-16be", "ascii", "latin1", "iso-8859-1"
  "mssql.splitPaneSelection": "next",
  "mssql.persistQueryResultTabs": false
}
// Query Formatting
{
  "mssql.format.alignColumnDefinitionsInColumns": false,
  "mssql.format.datatypeCasing": "none",
  "mssql.format.keywordCasing": "none",
  "mssql.format.placeCommasBeforeNextStatement": false,
  "mssql.format.placeSelectStatementReferencesOnNewLine": false
}
// Query Execution
{
  "mssql.query.displayBitAsNumber": true
}
// Shortcuts
{
  "mssql.shortcuts": {
    "event.toggleResultPane": "ctrl+alt+r",
    "event.toggleMessagePane": "ctrl+alt+y",
    "event.prevGrid": "ctrl+up",
    "event.nextGrid": "ctrl+down",
    "event.copySelection": "ctrl+c",
    "event.maximizeGrid": "",
    "event.selectAll": "",
    "event.saveAsJSON": "",
    "event.saveAsCSV": "",
    "event.saveAsExcel": ""
  }
}
// Status bar
{
  "mssql.statusBar.connectionInfoMaxLength": -1,
  "mssql.enableConnectionColor": true,
}
 See customize options and manage connection profiles for more details. Change LogSee the change log for a detailed list of changes in each version. Supported Operating SystemsCurrently this extension supports the following operating systems: 
Windows (x64 | x86 | arm64)macOS (x64 | arm64)Ubuntu 14.04 / Linux Mint 17 / Linux Mint 18 / Elementary OS 0.3Ubuntu 16.04 / Elementary OS 0.4Debian 8.2CentOS 7.1 / Oracle Linux 7Red Hat Enterprise Linux (RHEL)Fedora 23OpenSUSE 13.2Linux arm64 Offline InstallationThe extension will download and install a required SqlToolsService package during activation. For machines with no Internet access, you can still use the extension by choosing the Install from VSIX...option in the extension view and installing a bundled release from our Releases page. Each operating system has a .vsixfile with the required service included. Pick the file for your OS, download and install to get started. We recommend you choose a full release and ignore any alpha or beta releases as these are our daily builds used in testing. SupportSupport for this extension is provided via GitHub issues. You can submit a bug report, a feature suggestion or participate in discussions. Contributing to the ExtensionSee the developer documentation for details on how to contribute to this extension. Code of ConductThis project has adopted the Microsoft Open Source Code of Conduct. For more information see the Code of Conduct FAQ or contact opencode@microsoft.com with any additional questions or comments. TelemetryThis extension collects telemetry data, which is used to help understand how to improve the product. For example, this usage data helps to debug issues, such as slow start-up times, and to prioritize new features. While we appreciate the insights this data provides, we also know that not everyone wants to send usage data and you can disable telemetry as described in the VS Code disable telemetry reporting documentation. Privacy StatementThe Microsoft Enterprise and Developer Privacy Statement describes the privacy statement of this software. LicenseThis extension is licensed under the MIT License. Please see the third-party notices file for additional copyright notices and license terms applicable to portions of the software. |  |