I’ve previously written about SQL Server Profiler and its use in diagnosing problematic T-SQL queries, stored procedures, and application behaviours. Although the SQL Server Profiler is very much the trusted tool for doing so it’s actually marked as deprecated by Microsoft. This unfortunately means that it will be removed in a future version of SQL Server.
In place of Profiler there is another feature called Extended Events (also referred to as XEvents or XEs). As Microsoft’s intended replacement for the Profiler it’s important to learn how this feature works in anticipation for a future release of SQL Server where Profiler is no longer available.
A key advantage of Extended Events is that they are less performance intensive than what SQL Server Profiler is and that they are designed to be left running to collect data. You’ll also notice that Extended Event sessions are all done directly in SSMS rather than launching a separate tool. As sessions are stored as objects within the SQL Server instance other DBAs can also make use of them.
data:image/s3,"s3://crabby-images/19eef/19eefbe22168e9405dbb7048508de56a84315956" alt=""
Let’s work through a simple Extended Event session that will capture SQL queries being made in an AdventureWorks2022 test database.
Note: the following example was done on SQL Server 2022 CU17 running on Windows Server 2022 update 2025-01. SQL Server Management Studio 20.2 was used
Step 1: Launch SSMS from the start menu, login to the required SQL Server instance. Once you are logged in goto Instance Name > Management > Extended Events
Step 2: Create a session by right clicking the Sessions folder and clicking New Session Wizard.
Step 3: Click Next to skip past the introduction.
Step 4: Give your XEvent Session a descriptive name. For this example I’ve just used Tutorial 01. Click Next to proceed.
data:image/s3,"s3://crabby-images/7b813/7b813eca657941a3afc67a4bb5eb1c999518913c" alt="SSMS: Session Properties"
Step 5: Although there are some templates to choose from select Do not use a template and click Next.
data:image/s3,"s3://crabby-images/7162e/7162e89fa5884536526c7157c9ed3b3d26e84304" alt="SSMS: Templates"
Step 6: This page now allows you to select events you want to track. Search for the following events and then double click each line to add to the list to the right. Click Next once you have them all:
- sql_batch_starting
- sql_batch_completed
- sp_statement_starting
- sp_statement_completed
data:image/s3,"s3://crabby-images/077ea/077ea9de5f06dd21b4ca2dc0c87e457fa06c395a" alt="SSMS: Events To Capture"
Step 7: In the list of global events to track let’s select the following and then click Next:
- database_name
- process_id
- sql_text
- username
data:image/s3,"s3://crabby-images/04acc/04acc20bf76d24b9432a188b99dcb7b74ea49568" alt="SSMS: Capture Global Fields"
Step 8: For filters I’m going to add in a line to narrow down the XEvent to AdventureWorks2022 using the filter sqlserver.database_name. Click Next once set:
data:image/s3,"s3://crabby-images/3163d/3163d092c5152b917a78851778a3a7437cc97690" alt="SSMS: Sesseion Event Filters"
Step 9: Leave the data storage options unchecked for now. We’re only going to demo this XEvent so we aren’t interested in keeping the data. Click Next.
data:image/s3,"s3://crabby-images/73c46/73c46f4510b346b9fcf44cd87eb7f6459cc2f073" alt="SSMS: XEvent Storage Options"
Step 10: Review the summary and click Finish when you are satisfied with your selections.
data:image/s3,"s3://crabby-images/89114/89114ccd5c90c9d498147dd67e9e70e98ee34523" alt="SSMS: XEvent Summary"
Step 11: As we’d like to make use of this XEvent straight away check both options on the Summary screen then click Close.
data:image/s3,"s3://crabby-images/40c05/40c052aa82fba070cb5d021202a38aa2b27ee3db" alt="SSMS: XEvent Summary Screen"
You will then go back into SSMS. Note that the event Tutorial 01 now appears under Instance Name > Management > Extended Events > Sessions in the object explorer and also that a new window for the session events is open.
data:image/s3,"s3://crabby-images/7fa75/7fa7505f3097412f94e136b39fcfab70b9c4e6d8" alt="SSMS: Finished XEvent"
At this point make a simple select query on AdventureWorks2022. I did a lazy one just for demo:
SELECT * FROM [Person].[Address]
You’ll now see events tracking in the session event window:
data:image/s3,"s3://crabby-images/fa348/fa3486ec4e61bc71573242ea5fec827477a2e6d3" alt="SSMS: XEvent Query Window"
What you’ve just done is a simple session event trace but you can use the steps above to further customise your XEvent to capture the information you require.
Conclusion
We’ve discussed what SQL Server Extended Events are, what the advantages are, and performed a tutorial to build a very basic XEvent on a demo database.
If you organisation needs assistance with SQL Server we are here to help. Digital Incite and Matter Ltd’s consultants are SQL Server trained, certified and experienced with a wide variety of business applications. Get in touch with us today to discuss your requirements.