At home, my test environment for SQL Server runs on a Windows 10 PC. It’s the same PC that I use to do a bunch of different things & I don’t always want SQL Server running in the background so I’ve set the start mode for the service to Manual.
data:image/s3,"s3://crabby-images/14451/1445114d4732d2034e02d29c362003ed7150a849" alt=""
However, because shutting down Windows 10 doesn’t do what I would expect it to, I often find that SQL Server is still running when I start up my PC the next time. And even though I know it won’t stop on its own, I keep forgetting to shut it down at the end of the last session. Also, I’m lazy – the several clicks it takes me to open SQL Server Configuration Manager is clearly too much for me. 😅
So, having learned a bit about PowerShell in the past few months, I’ve decided to put it to use so the next time I log on, I’m not wondering why SQL Server is eating up half of my computer’s resources.
Aim: Create a PowerShell script that starts or stops the SQL Server service & execute it from a Desktop shortcut.
After some trial & error, here’s my script saved to a ps1 file. It’s probably not the most elegant, but it’s my first time using PowerShell in anger so it’ll do (& I’ll get better with more practice!). Based on the input parameter $start
which can be either 1 or 0, Start-Service
or Stop-Service
will be run for the default instance of SQL Server.
data:image/s3,"s3://crabby-images/acaf8/acaf83e59cdc56edf7575560d99297288c06b3a0" alt=""
This is what happens when I run the script directly in PowerShell to shut down SQL Server. The script will ask for a value to be supplied (!? will helpfully return the Help Message I included in the script in case I ever forget what the allowed values are). Once the SQL Server service has stopped, it’s current status will be returned by Get-Service
(this is only relevant for executing the script directly in PowerShell).
Note: PowerShell must be run as administrator to execute this script due to it starting/stopping a service.
data:image/s3,"s3://crabby-images/e3b15/e3b15a74be93203695e128082fa6bb51665236d7" alt=""
And when I refresh SQL Server Configuration Manager, I can confirm that the service is indeed stopped.
data:image/s3,"s3://crabby-images/9c297/9c2972add6a05c4109e3166d75a88c1c708a21d9" alt=""
Same in the opposite direction to start the service. This time around, I’ve passed in the value for the parameter in the same line where I execute the script, rather than waiting for it to prompt me.
data:image/s3,"s3://crabby-images/bb4a6/bb4a660ed0ee0a5b9fcde8cc80095bdd87e37e1e" alt=""
Now, I’m no more likely to launch PowerShell as an administrator & execute my script from there than I am to remember to shut down SQL Server from Configuration Manager when I’m done with it, so the next step is to put a Desktop shortcut in place so I can just double-click on it when I’ve closed all the other windows I’m working with.
First, I right-click my ps1 file and create a shortcut, then rename it to something more useful (e.g. “Start or Stop SQL Server”) and move it to the Desktop.
data:image/s3,"s3://crabby-images/09771/09771e7a22dbd0631b82f34a770d2cd96f7dbb85" alt=""
And when I double-click on the shortcut… it just opens the script in Notepad, rather than executing it. Not the desired behaviour!
However, thanks to a SuperUser query from over a decade ago, I’ve found that the way to fix this is to open the Properties of the shortcut & in the Shortcut tab, prefix the path in the Target field with powershell.exe -f
.
data:image/s3,"s3://crabby-images/fa22d/fa22d6b300a29dd8974153a95ccade08a2e5dc1f" alt=""
Then, click Advanced & tick Run As Administrator. Without the addition of powershell.exe -f
to the Target field, this option will remain greyed out.
data:image/s3,"s3://crabby-images/8e84c/8e84ca2dbacb00cc8affdc4b07530d1bfe7895d7" alt=""
Once those changes are made, double-clicking on the shortcut will open a prompt asking “Do you want to allow this app to make changes to your device?”. Clicking Yes will open the familiar Administrator session in PowerShell & supplying the correct value for the $start
parameter will start or stop SQL Server as desired.
data:image/s3,"s3://crabby-images/91a48/91a4831ca798c7ade0bb27a7f9ea433cf489a6db" alt=""
Most excellent!
Yes, there may be as many clicks involved as launching SQL Server Configuration Manager & stopping SQL Server from there, but with a big shortcut on my Desktop, I’m less likely to forget to actually stop the service when I’m done with it.
data:image/s3,"s3://crabby-images/a3537/a35372c0769a3cd41d04d731134d2724f4f496c9" alt=""
Next: Now that I’ve got a PowerShell script that I can easily run, can I automate it to run on logon so I don’t even need to do the manual steps to stop SQL Server?
Be First to Comment