I just downloaded the latest version of SQL Express 2012 but I cannot connect to localhost. I tried localhost\SQLExpress and Windows authentication but it gives me an error message saying cannot connect. Am I missing something here? I've used SQL Server 2008 before and I've never had issues connecting to localhost. It seems that it can't even find it. Also in the Services I only see a SQL Server VSS Writer. Is this the way it should be? Or am I missing something? Thanks
-
1Seems the installation didn't go well. Did you try repairing/re-installing it? – Vikdor Oct 08 '12 at 03:24
-
1Are you sure you found the installer for the server, as opposed to, say, a Management Studio installer? – Damien_The_Unbeliever Oct 08 '12 at 05:32
14 Answers
You need to verify that the SQL Server service is running. You can do this by going to
Start > Control Panel > Administrative Tools > Services
, and checking that the service SQL Server (SQLEXPRESS
) is running. If not, start it.While you're in the services applet, also make sure that the service SQL Browser is started. If not, start it.
You need to make sure that SQL Server is allowed to use TCP/IP or named pipes. You can turn these on by opening the SQL Server Configuration Manager in
Start > Programs > Microsoft SQL Server 2012 > Configuration Tools
(orSQL Server Configuration Manager
), and make sure that TCP/IP and Named Pipes are enabled. If you don't find the SQL Server Configuration Manager in the Start Menu you can launch the MMC snap-in manually. Check SQL Server Configuration Manager for the path to the snap-in according to your version.Verify your SQL Server connection authentication mode matches your connection string:
If you're connecting using a username and password, you need to configure SQL Server to accept "SQL Server Authentication Mode":
-- YOU MUST RESTART YOUR SQL SERVER AFTER RUNNING THIS! USE [master] GO DECLARE @SqlServerAndWindowsAuthenticationMode INT = 2; EXEC xp_instance_regwrite N'HKEY_LOCAL_MACHINE', N'Software\Microsoft\MSSQLServer\MSSQLServer', N'LoginMode', REG_DWORD, @SqlServerAndWindowsAuthenticationMode; GO
- If you're connecting using "Integrated Security=true" (Windows Mode), and this error only comes up when debugging in web applications, then you need to add the ApplicationPoolIdentity as a SQL Server login:
otherwise, run
Start -> Run -> Services.msc
If so, is it running?
If it's not running then
It sounds like you didn't get everything installed. Launch the install file and chose the option "New installation or add features to an existing installation". From there you should be able to make sure the database engine service gets installed.

- 681
- 9
- 18

- 17,226
- 9
- 43
- 70
-
2
-
3Another thing to check is the instance name. Depending on how SQL Server was installed you may or may not need to provide an instance name after the host. – Arvo Bowen Jul 05 '16 at 15:07
-
"TCP/IP and Named Pipes are enabled" seems to be necessary after first installing – James A Mohler Feb 18 '17 at 04:12
-
-
7It was stupid but for me, the problem was using "localhost" as the server name and not "localhost\SQLEXPRESS01" as was set in the installation – Guy s May 17 '18 at 11:07
-
Note that if you're using the default instance name like MSSQLSERVER or SQLEXPRESS then you might be able to connect with just "LocalHost". In fact, using the full name like LocalHost\MSSQLSERVER might not work (did not for me). Yet, for a custom instance name like SQLEXPRESS01 you must include the name. And up vote Ravindra for helpful info. – Yogi Nov 13 '18 at 23:19
-
1In my case SQLBrowser was disabled and the configuration tool wasnt listed in the sql tools folder. To start the config tool via cmd [https://learn.microsoft.com/en-us/sql/relational-databases/sql-server-configuration-manager?view=sql-server-2017](https://learn.microsoft.com/en-us/sql/relational-databases/sql-server-configuration-manager?view=sql-server-2017) To start the SQLBrowser automatically if the config tool fails [https://stackoverflow.com/questions/21375014/i-cannot-start-sql-server-browser](https://stackoverflow.com/questions/21375014/i-cannot-start-sql-server-browser) – steven87vt Jan 22 '19 at 16:27
-
Adding the User and setting their permissions to *db_owner* fixed my issue. – AriBaa Games Mar 01 '19 at 15:38
-
"Windows could not start the SQL Server (MSSQLSERVER) on Local Computer" – DFSFOT Mar 28 '19 at 14:02
-
In 2022 this is STILL the solution to connect to SQL Server Express locally using a non-Management Studio tool! – Joseph May 27 '22 at 09:16
Goto Start -> Programs -> Microsoft SQL ServerYYYY -> Configuration Tools -> SQL Server YYYY Configuration Manager or run "SQLServerManager12.msc".
Make sure that TCP/IP is enabled under Client Protocols.
Then go into "SQL Server Network Configuration" and double click TCP/IP. Click the "IP Addresses" tab and scroll to the bottom. Under "IP All" remove TCP Dynamic Ports if it is present and set TCP Port to 1433. Click OK and then go back to "SQL Server Services" and restart SQL Server instance. Now you can connect via localhost, at least I could.
Note that this error can of course occur when connecting from other applications as well. Example for a normal C# web application Web.config
connection string:
<connectionStrings>
<add name="DefaultConnection" connectionString="server=localhost;database=myDb;uid=myUser;password=myPass;" />
</connectionStrings>

- 62,132
- 37
- 328
- 418
in SQL SERVER EXPRESS 2012 you should use "(localdb)\MSSQLLocalDB" as Data Source name for example you can use connection string like this
Data Source=(localdb)\MSSQLLocalDB;Initial Catalog=master;Integrated Security=True;

- 421
- 4
- 4
-
3Great! Using (localdb)\MSSQLLocalDB worked to connect to SSMS when localhost didn't work – Ben Oct 23 '20 at 05:02
-
-
First try the most popular solution provided by Ravindra Bagale.
If your connection from localhost to the database still fails with error similar to the following:
Can't connect to SQL Server DB. Error: The TCP/IP connection to the host [IP address], port 1433 has failed. Error: "Connection refused: connect. Verify the connection properties. Make sure that an instance of SQL Server is running on the host and accepting TCP/IP connections at the port. Make sure that TCP connections to the port are not blocked by a firewall."
- Open the SQL Server Configuration Manager.
- Expand SQL Server Network Configuration for the server instance in question.
- Double-click "TCP/IP".
- Under the "Protocol" section, set "Enabled" to "Yes".
- Under the "IP Addresses" section, set the TCP port under "IP All" (which is 1433 by default).
Under the "IP Addresses" section, find subsections with IP address 127.0.0.1 (for IPv4) and ::1 (for IPv6) and set both "Enabled" and "Active" to "Yes", and TCP port to 1433.
Go to
Start > Control Panel > Administrative Tools > Services
, and restart the SQL Server service (SQLEXPRESS
).

- 35,493
- 19
- 190
- 259
-
1I tried the other solutions above before getting here. This one fixed it for me! Also, I found downloading a thing called psping helped me test the connection. Example: psping 127.0.0.1:1433 – KANJICODER Apr 14 '18 at 10:44
-
it did not work for me until I set IP Address `127.0.0.1` and port `1433` on IP4 – xinthose Jan 05 '21 at 19:30
I had a similar problem - maybe my solution will help. I just installed MSSQL EX 2012 (default install) and tried to connect with VS2012 EX. No joy. I then looked at the services, confirmed that SQL Server (SQLEXPRESS) was, indeed running.
However, I saw another interesting service called SQL Server Browser that was disabled. I enabled it, fired it and was then able to retrieve the server name in a new connection in VS2012 EX and connect.
Odd that they would disable a service required for VS to connect.

- 111
- 1
- 2
-
It isn't required to connect; I have it disabled and I can connect fine. It just makes things easier when you don't know the precise host/instance name to connect to as it allows those things to be queried by other software. – Simon Morgan Apr 29 '19 at 09:01
First check SQL Server Service is Running or stopped, if it is stopped just start it, to do so..just follow the below steps.
1.Start -> Run ->Services.msc
- Go to Standard tab in services panel then search for SQl Server(SQL2014)
"SQL2014" is given By me, it may be Another Name in your case
that's it once you start the SQL Service, you are able to connect local database.
hope it will help someone.

- 1,431
- 19
- 39
All my services were running as expected, and I still couldn't connect.
I had to update the TCP/IP properties section in the SQL Server Configuration Manager for my SQL Server Express protocols, and set the IPALL port to 1433 in order to connect to the server as expected.

- 18,116
- 40
- 128
- 186
After doing the steps which were mentioned by @Ravindra Bagale,
Try this step.
Server name: localhost\{Instance name you were gave}

- 185
- 2
- 9
The problem for me was that I was not specifying .\
. I was only specifying the name of the instance:
- did not work:
SQL2016
- worked:
.\SQL2016

- 2,365
- 2
- 23
- 29
This is odd I have a similar problem. I downloaded the package for SQL 2012 Express with Tools but the Database Engine was not install.
I donloaded the other one from the MS site and this one installed the database engine. After a reboot the services were listed and ready to go.

- 11
- 1
My situation
empty Instance Name in SQL Server Management Studio > select your database engine > Right Mouse Button > Properties (Server Properties) > Link View connection properties > Product > Instance Name is empty
Data Source=.\SQLEXPRESS did not work => use localhost in web.config (see below)
Solution: in web.config
xxxxxx = name of my database without .mdf yyyyyy = name of my database in VS2012 database explorer
You can force the use of TCP instead of shared memory, either by prefixing tcp: to the server name in the connection string, or by using localhost.

- 11
- 1
I had the same issue and I found that this happened after I installed an update for my SQL 2012. What fixed it for me was going into programs and features and running a repair on it.

- 71
- 1
- 6
Try changing the User that owns the service to Local System or use your admin account.
Under services, I changed the Service SQL Server (MSSQLSERVER) Log On from NT Service\Sql... To Local System. Right click the service and go to the Log On Tab and select the radio button Local System Account. You could also force another User to run it too if that fits better.

- 405
- 4
- 16