Never did I think that I'd be able to run SQL Server on my Mac. My, how times have changed. For the first time, SQL Server 2017 allows users to install the product on Linux. This opens the doors for working with fully-featured SQL Server database engines on MacOS through freely distributable Docker containers.
With the addition of a new graphical user interface that's in public preview, Mac users can now leverage the same industry-leading database platform that has previously only been available to Windows users, all on their local computer. Let me show you how to get started in three easy steps.
Pull the SQL Server 2017 container Next, start up Terminal.app. This is where you'll issue commands to Docker. Microsoft provides that include the Developer edition of SQL Server 2017 running on Ubuntu Linux. You can pull the most recent version with the following command. Sudo docker pull microsoft/mssql-server-linux:2017-latest After supplying your MacOS Administrator password, the image is downloaded.
Docker images need to be unpacked into containers, and a single image can be used to create as many identical containers as you'd like; just be sure to give them unique names. The following command will create a single container called 'sqlserver1' from the image you just downloaded. A couple of points:. Note that you'll want to provide your own strong password for the SQL Server System Administrator account. Just replace 'YourStrong!Passw0rd' with something better. Port 1401 on the local computer will be forwarded to SQL Server's default listening port of 1433 inside the container.
This will be important to remember later. Make sure that you forward a different port to 1433 if you decide to create additional containers. Sudo docker run -e 'ACCEPTEULA=Y' -e 'MSSQLSAPASSWORD=YourStrong!Passw0rd' -p 1401:1433 -name sqlserver1 -d microsoft/mssql-server-linux:2017-latest To verify that everything is working as intended, you can check the status of Docker's containers. Docker ps -a. Install SQL Operations Studio Microsoft is in the beginning stages of developing a cross-platform graphical user interface for SQL Server called SQL Operations Studio. Though it's still in an early public preview, SQL Ops Studio is already showing promise as a robust, lightweight interface that brings the best of SQL Server Management Studio (a venerable workhorse, but sadly Windows-only) over to the Mac and Linux platforms. The will be your source of information as the project progresses.
Head over to the GitHub repository, scroll down to the first section of the readme and download the MacOS zip containing the latest stable preview. Upon Operations Studio's first launch, the Connection window will automatically prompt you for login credentials. Use 'localhost' as the name of the server, 'SA' as the user name, and fill in the password that you established when the Docker container was created. Then press the Advanced button, and scroll through the properties list until you get to the General section. Fill in the port number of 1401 here, or whichever port you're passing to SQL Server's 1433 listening port. Press OK, then Connect. That should connect, and pass you back to the main interface.
If you've ever seen, then you'll instantly recognize the interface's clean and well-organized layout. On the left is a listing of servers you're connected to. Expand the server folder to explore databases, security items and so on. You're now up and running with the SQL Server database engine running in a Docker container, and you can manage it with Operations Studio on your Mac! Bonus step 4. Start working with your new SQL Database Engine What good is a server without a database? Right-click the Databases folder, and choose New Query.
Database Server For Mac
In the SQLQuery1 tab, type in the following command. CREATE DATABASE MyDatabase; GO Press the Run button to create your first database, which you should see pop up under the Databases folder.
You might need to right-click the databases folder and choose Refresh if it doesn't show up immediately. Operations Studio has a great feature called Snippets that help you quickly write common T-SQL commands. Clear out the CREATE DATABASE statement and change the Connection drop-down at the top to MyDatabase. Type 'sql' to see the list of included snippets presented in the IntelliSense popup box.
Notice that all of the TableName placeholders are selected, ready for you to overwrite them with your own name. Type it once, and each one gets updated simultaneously. Press the tab key to move over to SchemaName and change that to 'dbo' (since we haven't created any other schemas at this point).
Then all that's left is to modify the Column1 and Column2 placeholders on lines 10 and 11, choose appropriate data types, and add additional columns as needed. Press the Run button when done to create your first table, in your first database, on your SQL Server instance, running on Ubuntu Linux, inside of a Docker container, on your Mac.