SQL Server Troubleshooting: The Instance ID ‘MSSQLSERVER’ is already in use by SQL Server instance ‘MSSQLSERVER.INACTIVE”
During weekends, playing with SQL Server have always been a hobby. We have entire lab setup at home. We call it “Playground”. Was recently doing an upgrade from SQL Server 2008 to SQL Server 2014. Due to some error, the upgrade failed and as a last resort, re-installed SQL Server. Un-install was clean. Started installation process and when selected instance type as “Default Instance”, encountered a weird error: “The Instance ID ‘MSSQLSERVER’ is already in use by SQL Server instance ‘MSSQLSERVER.INACTIVE’ “. The error is pretty clear. All we have to do is remove MSSQLSERVER.INACTIVE to fix the issue. Here is a brief description of what should be done to fix the issue.
Steps to fix the issue:
- Search your machine for files called Datastore_Discovery.xml (depending on how much you’ve got or done, you might see many of these… just open the most recent one and you’ll be fine.
- Open Datastore_Discovery.xml in an editor… given the formatting, what worked was in Visual Studio 2008/2010 and clicking Edit, Advanced, Format Document (this arranges the XML nicely)
- What you’re looking for are all places where MSSQLServer.Inactive exists in the document as the Instance ID. Below is a sample of how the line starts:
<Instance Urn=”Machine[@ID=’IWE’]/Product[@ID=’SQLVNEXT’]/Instance[@ID=’MSSQLSERVER.INACTIVE’]” ID=”MSSQLSERVER.INACTIVE” Name=”MSSQLSERVER.INACTIVE” ……..
- Scroll along the lines around the above one and find the following value field: ProductCode=”{9FFAE13C-6160-4DD0-A67A-DAC5994F81BD}. There might be multiple ProductCodes, depending on how many times the <Instance URN…> line lists MSSQLServer.Inactive, so make sure to find all ProductCodes.
- Now open a command line and for each of the ProductCodes that you found for the Inactive SQL Instances, type the following:
msiexec /x {9FFAE13C-6160-4DD0-A67A-DAC5994F81BD}
- Do this for each Product Code that relates to an Inactive Instance
- Once complete, go back to your SQL installation media and run Setup
- Once the main splash screen launches, click Tools, then Installed SQL Server features discovery report
- This will launch a web page listing the SQL Instances and all features per instance. If you still see any MSSQLSERVER.INACTIVE there, you missed one of the ProductCodes and you need to double check. Otherwise, all of the orphaned SQL Instances should now be gone, and you can either Add Features or do a clean Default Instance reinstall.
Hope this will help everyone for sure!