How to insert data from Excel to SQL Server

Written by Johannes Åkesson
Reviewed by Johannes Åkesson
Jan 20, 2025
16 min read

In this article, you’re going to learn 2 easy ways to perform one of the most useful data management tasks: how to insert data from Excel to SQL Server. For more technical users, a Copy and Paste method in Management Studio can be a useful trick, but the real winner is the SQL Spreads method, which makes it quick and easy even for business users, with plenty of safeguards in place to keep your data safe.

Watch this video for a brief introduction to the two simple methods found in this article, and read on for the step-by-step instructions.

I built SQL Spreads for easier data import into SQL Server

Before I founded SQL Spreads (an Excel Add-in to Import and Update SQL Server data from within Excel), I worked as a Business Intelligence consultant for many years using Microsoft’s BI-tools, such as SQL Server, SSIS, Reporting Services and Excel, among others.

I’ve found that when working on different projects, I tend to snap up a number of great-to-know things that I can re-use over and over again. One of these skills that I re-use in almost every project is the ability to copy and paste data from Excel into a table in SQL Server.

It’s a really simple and convenient way to quickly import data into a table via SQL Server Management Studio.  For example, populating a new dimension table, adding some test data, or inputting any other data that you need to quickly get into a table in SQL Server.

But what if you want to insert data from Excel to SQL without using Management Studio?  What if business users, who are not familiar with SSMS, want to import the data without first running it by you? Is there a way to do this directly from Excel? Yes! This is where the SQL Spreads Excel Add-In that I’ve been working on over the last few years comes in.  It makes your Excel to SQL Server import tasks much easier to do!

4 benefits of importing dating directly from Excel: 

There are several benefits to importing data to SQL Server directly from Excel, for instance: 

  • It takes time for someone in the IT/BI department to fulfil requests from business to get ad hoc data inserted into SQL Server frequently. This task should be moved over to the business users in a responsible way.
  • Many business users are more comfortable with Excel than database tools. An Excel add-in for importing data into SQL Server means they can handle this process on their own. 
  • Many Excel-to-SQL add-ins (like SQL Spreads) allow you to validate data in real time. If there are validation issues, they can be fixed on the fly before pushing data to the server.
  • It’s easier to visualize any data in Excel, and thus easier to update accurately.

In this article, I’m going to explain how to insert data from Excel to SQL Server using these 2 different, reliable methods:

  • Method 1: Use SQL Spreads to insert directly from Excel to SQL tables – the easy option for both business users and tech team members
  • Method 2: Use SSMS to copy and paste from Excel to SQL tables – a solid solution for team members with deeper technical know-how

Empower your business users to safely update SQL data themselves—without risking your database integrity. With SQL Spreads, your data is safe, the team can handle data updates, and you can focus on your more important tasks.

Method 1:

How to import data from Excel to SQL Server – SQL Spreads method

This method is ideal for business users who don’t want to insert data using SQL Server Management Studio – or don’t quite have the skillset required to work in SMSS. 

You may have business users constantly interrupting your work to get data into SQL Server, or you spend too many hours every day dealing with validation issues that bounce back and forth for fixes. Exhausting, right?

The SQL Spreads method eliminates these hassles, letting business users stay in their beloved Excel for data entry and immediate validation, while you’re free to focus on other tasks without worrying that the data isn’t updated correctly.

The video below gives you a quick overview of how business users can insert data from Excel into SQL Server.

Let’s walk through the exact steps to follow to insert (or import) data from Excel to SQL Server using the SQL Spreads method:

Designer tasks:

  1. Install SQL Spreads Excel Add-In
  2. Connect to your SQL Server database
  3. Select your database table

Data Editor tasks:

  1. Insert new rows
  2. Update existing data

Designers vs Editors

The beauty of SQL Spreads is that the Designer only has to handle steps 1-3 here. Once everything is set up and SQL Spreads is downloaded for each user, you can safely hand over the rest of the work to your business users in the Data Editor role. They can then easily insert new rows in Excel or update existing data that is already in SQL Server without risking the integrity of the data or its configuration.

Step 1: Install the SQL Spreads Add-In for Excel

First, download a free trial of SQL Spreads. Our 14-day trial gives you access to all of the features, such as data validation and change tracking, so you can really get a sense of how to leverage the tool to maximize efficiency for your specific needs.

  1. Run the SQLSpreadsSetup.exe file and follow the instructions.
  2. Restart Excel and accept the Add-In confirmation.
  3. You will find SQL Spreads in the tab menu in Excel:
View new SQL Spreads tab in the Excel ribbon after installation

For more details about installation, check out the Installing SQL Spreads section of our Knowledgebase.

Step 2: Connect to your SQL Server database

Once SQL Spreads is installed, you’ll see that it has been added as a new ribbon tab. Our Designer and Editor permission roles ensure that you are in charge of configuration, while the business user is only able to edit data according to the parameters you set up.

  1. Click on SQL Spreads and then click the Open Designer button
    Click on the Open Designer button in the SQL Spreads ribbon to open it up
  2. In the SQL Spreads Designer panel on the right side, click the Edit button to open the SQL Server connection dialog.
    Connect Excel to SQL Server by clicking on the Edit button in the documents SQL Server connection
  3. Enter the name of your SQL Server into the SQL Server name field:
    Connect to SQL Server by configuring the server name in the dialog
  4. Select if you should connect using your Windows-login (Windows Authentication) or enter a user name and password (SQL Server or Azure AD Authentication). Windows and Azure AD authentication are the more secure options.
    Select one of three authentication options to configure connection to SQL Server to import data from Excel
  5. Click OK. SQL Spreads will try to connect to the database. If the connection is successful, your databases will show up in the SQL Spreads Designer panel.
    A list of all databases, that you have access to, will be visible in the SQL Spreads Designer

Step 3: Select your SQL Server table

Now that we’ve created the connection from Excel to SQL Server, we can select which table of data we want to use in Excel. In the SQL Spreads Designer, click on the database and then select your table.
Select your SQL Server table that you would like to start updating from Excel.

As soon as you select a table, the data in the table is populated in the Excel sheet.  You can now see all the data in your SQL Server table and use it in your Excel workbook, and this is the real power with SQL Spreads: the ability to update or add to the data in SQL Server directly from Excel.

Time to hand over to business users

With the connection between SQL Server and Excel made, and with everything set up to your specifications, now it may be time for you to hand over the reins to a business user. Here’s how easy it is to add new rows or edit existing data:

Step 4: Inserting new rows into SQL Server

A business user, with a Data Editor role assigned to them, will need to download the SQL Spreads Excel Add-In. Then they will open up the Excel document created by the Designer (steps 1 to 3 above).

To import new data into SQL Server, they will scroll down to the first empty row and either type in their new data or paste a set of rows copied from another Excel workbook:

Insert data in the first empty row at the end of the table to insert data into SQL Server

Once you’ve added or pasted the new rows, click the ‘Save to Database‘ button to get the changes written to the table in SQL Server.

Step 5: Updating existing data in SQL Server

You can also update data in the employee table directly in Excel, and save the changes back to SQL Server.  To do this you simply make the edits in the table in Excel and then click on the ‘Save to Database‘ button to get the changes written to the table in SQL Server.

Data is automatically validated with each entry against the data types in the SQL Server database, ensuring database integrity. The Designer can also ensure that only those columns where an Editor should be able to add or edit data are available to them.

Update an existing value in the SQL Server table and save the changes back to the database.

Success!

In 2 quick steps, your business user updated the database without ever leaving their Excel spreadsheet.

Did you see how easy that was to get business users to update SQL data using SQL Spreads? Quick, easy, and well on your way, that’s the power of SQL Spreads.

Method 2:

How to import data from Excel to SQL Server – Copy and Paste method

Watch this video to find out how the Copy and Paste method works best for more technical users to import data from Excel to SQL Server.

Step-by-step instructions using SSMS

  1. Open SQL Server Management Studio and connect to your SQL Server database.
  2. Expand the Databases and the Tables folders for the table where you would like to insert your data from Excel.
  3. Right-click the table and select the fourth option – Edit Top 200 Rows.
  4. The data will be loaded and you will see the first 200 rows of data in the table.
  5. Switch to Excel and select the rows and columns to insert from Excel to SQL Server.
    Right-click the selected cells and select Copy.
  6. Switch back to SQL Server Management Studio and scroll down to the last row at the bottom and locate the row with a star in the left-most column.
  7. Right click the star in the column header and select Paste.
  8. You have now completed your SQL Server import, and your data from Excel is now in a table in SQL Server!

Remember: Always start with copying and pasting a single row of data from Excel to SQL Server. This is to check that there are no mismatches between your data from Excel and the SQL Server table (such as the number of columns) and that your data in Excel validates with the data types in the SQL Server table. See the section “Tips and tricks” below for more details.

How to insert data from Excel to SQL Server with an identity column

The same technique can also be used to copy and paste data into tables that have an auto-incrementing ID column (identity column).

SQL Spreads shortcut

When working with ID columns in SQL Spreads, there is no need to remember to add in the extra column as in the tutorial below – the primary key and auto incrementing ID column are automatically sorted 

The thing to keep in mind here is to also include an extra left-most blank column in Excel when copying the data from Excel to SQL Server.

Follow these steps to copy and paste the data from Excel to SQL Server using a table with an auto-incrementing ID column:

  1. Open SQL Server Management Studio and connect to your SQL Server database.
  2. Expand the Databases and the Tables folders for the table where you would like to paste the Excel data.
  3. Right-click the table name and select Edit Top 200 Rows, the fourth option from the top.
  4. This will bring up a grid with the first 200 rows of data in the table.
  5. Switch to Excel and select the rows and columns to copy. Do not include the header row.
    Now, also remember to include an extra blank left-most column in your selection.

    Then, right-click the selected cells and select Copy.
  6. Switch back to SQL Server Management Studio, and select the tab with the 200 rows from your table.
    Go to the last row at the bottom and locate the row with a star in the left-most column.
  7. Right-click on the star and select Paste.
  8. Your data from Excel is now pasted into your table in SQL Server, and SQL Server will automatically create the values in the ID/key column for you:

Wary of letting your business users update SQL data? Let’s change that. With SQL Spreads, business users can safely update their data in a guided way controlled by you. The database remains intact – and you can focus on your most important tasks.

Try it yourself – 14 days for free

Get your SQL Spreads trial here

Copy and paste data from Excel to SQL Server Views

The copy and paste method also works when your Excel to SQL Server import is to a View as opposed to a Table.  The only requirement is that the View should only contain data from one table.

In a View in SQL Server that contains data from several joined tables you cannot insert new rows, but you can update the data, as long as you only update columns that originate from the same base table.

SQL Spreads shortcut

Want to import data to a View while working in SQL Spreads? No problem. It’s easy to do, right within Excel. Read our article on How to update a View in SQL Server from Excel for a quick guide. 

Excel to SQL Server import on a remote machine

When working with SQL Server databases on a remote machine, where you connect to the remote machine using a Remote Desktop Connection, you can still use the same copy and paste technique to move the data from your local machine’s Excel to the SQL Server database on your remote machine.

If you are not able to copy and paste the data into your SQL Server when connected using a Remote Desktop Connection, first check that copy and paste is enabled for the Remote Desktop Connection:

  1. Open the Remote Desktop Connection.
  2. Click the Show Options…
  3. Select the Local Resources tab, and then check that the Clipboard property is checked:

If you still cannot copy and paste data between Excel on your local machine and SQL Server on your remote database server, verify with your server administrator that the copy and paste feature is enabled for the Remote Desktop Connection on the server.

Tips when copying and pasting data from Excel to SQL server

Validating your data – start with one row of data

If the data that you copy from your Excel document does not match the data types of the columns in your SQL Server table, the inserting of the data will be canceled and you will get a warning message. This will happen for every row you paste from Excel to SQL Server. If you paste 500 rows from Excel with the wrong number of columns, you will get one warning message for each and every row that you paste – an exhausting prospect, to say the least.

SQL Spreads shortcut

SQL Spreads solves this issue by empowering business users to update their own data and by immediately validating each data point, letting the business user correct it before it even attempts to move to SQL Server – keeping you out of the process entirely

To avoid this, the trick is to start to copy only a single row of data and paste it into the SQL Server table. If you get a warning message for incorrect data types, you can correct the mismatch and repeat the copy and paste procedure until all your Excel columns fit into the table in SQL Server. When all columns match, select the remaining rows and paste them all into the SQL Server table in one step.

Data validation was one of my top priorities from the start with SQL Spreads. I wanted to make sure this step was automatic, so that anytime I or a non-tech business user edited data, it would be checked against the data type in SQL Server, saving both time and headaches.

Inserting NULL values from Excel into a SQL Server table

When you have columns in your SQL Server table that allow NULL values, and you want to insert a NULL value into the table, just enter the text NULL into the cell in Excel, and then copy and paste the data from Excel into SQL Server:

The NULL values will be inserted into the table in SQL Server:

SQL Spreads shortcut

SQL Spreads has an automatic NULL identifier with easy set-up

Tables with computed columns

For SQL Server tables containing computed columns, you can paste data from Excel into that table simply by leaving the data for the computed column blank in Excel, and then copying and pasting the data from Excel into the SQL Server table.

SQL Spreads shortcut

SQL Spreads has the ability to detect a formula column (when enabled) and save the results back to the database. 

How to get the column names from the table in SQL Server to Excel

SQL Spreads shortcut

If you are working in SQL Spreads, you don’t have to worry about column names or making sure they match when bringing into Excel from SQL Server. SQL Spreads automatically loads SQL Server headers/table column names into Excel. 

When you prepare the data in Excel for import into an existing SQL Server table, it is useful to have the column headings and a few rows of sample data as a reference in Excel.

There is a technique where you can copy existing data in SQL Server to Excel and include the table column names as header names.

Follow these steps to also include the column names when copying a few rows of data from a SQL Server table into Excel:

  1. In SQL Server Management Studio, locate your database and expand the Tables folder.
  2. Right-click your table name and select the third option – Select Top 1000 rows.
  3. Select the rows to copy to Excel by holding down the CTRL button and clicking the row numbers on the left side.
  4. When your rows are selected, right-click one row and select the Copy with Headers option:
  5. Go to Excel and paste the data into a cell. The headers from the table in SQL Server will now be added as the first row:

Excel to SQL Server performance

Copying and pasting data from Excel to SQL Server is a simple method to import data from Excel into your SQL Server database. One of the drawbacks is that it is not the fastest method if you need to insert larger amounts of data, such as several hundred thousand rows of data or more.

To get a reference to the performance limits, I have run a few tests on my local i7 machine with 8 GB of RAM with Microsoft Excel and SQL Server installed on the same machine.

I had the following results for copying 10 columns of mixed data types in Excel to SQL Server:

  • ~ 2 seconds for 100 rows
  • ~ 30 seconds for 1000 rows
  • ~ 10 minutes for 20,000 rows.

So, I would say that the limit to use the copy and paste feature is around a few thousand up to a few tens of thousands of rows of data.  If you need to perform an Excel to SQL Server import with more data, then you should use the SQL Server Import and Export Wizard or SQL Spreads.

SQL Spreads is much faster to use! These are the comparative performance results for saving data back to SQL Server from Excel using SQL Spreads for the same data scenario:

  • ∼ Less than 1 second for 100 rows
  • ∼ 1 second for 1000 rows
  • ∼ 9 seconds for 20,000 rows

And when you get to 50 000+ rows, we have a nifty feature, Tree Filters, that helps with keeping optimal performance in check!

Copy and paste – a quick reference

We’ve just covered all of the steps of the copy and paste method, and it quickly gets complicated. So here is a short version: 

  • First, copy the data from Excel, and then paste it into the SQL Server table using the Database > Table > Edit top 200 rows menu option.
  • Always start by copying and pasting a single row of data to validate the data types.
  • For SQL Server tables with an identity column, add an extra blank left-most column before copying from Excel.
  • Copy and paste from Excel to SQL Server can be used to insert up to a few tens of thousands of rows of data.
  • To get the SQL Server column headers into Excel, right-click the table in SQL Server and select Copy with headers.
  • Don’t forget that the technique also works great over Remote Desktop Connections!

SQL Spreads shortcut

Skip all of these SSMS steps and use SQL Spreads rather. Your company will thank-you for getting business users involved directly. 

Other tools and techniques for importing Excel data to SQL

There are some other ways to import an Excel file to a table in SQL Server. Here are some of the other methods.

  • SQL Server Import Wizard – a wizard-based import tool inside SQL Server Management Studio. Ideal for one-time imports when you have an Excel document that you need to import into a table in SQL Server.
    – The pros include flexibility and lots of settings to fine tune the import.
    – The biggest drawback is that you need to run through a dozen Wizard dialogs with lots of settings each time you need to import the data.

    Find out more info about the SQL Server Import Wizard.

  • SSIS – this is the oil tanker for moving data between different sources. You can do almost any task you like, but you will need to put in lots of time to get started, and it will take still more time to maintain and change the solution down the line.
    – The pros include good versatility and plenty of available features.
    – The main con is the time you will have to put in to learn the tool.

    Find out more info about SSIS.

  • The BCP utility – a command line-based tool that offers a huge number of settings – if you are a coder, this is the tool to use. Find out more info about the BCP utility.

Get business users to insert data from Excel to SQL now

IIn this article, we’ve looked at 2 easy ways to insert data from Excel to SQL Server.

If SQL Server Management Studio is not a convenient alternative for you and your business users, the SQL Spreads Excel Add-In will enable you to effortlessly insert data from Excel to SQL Server. One main draw is that it’s just as quick and easy to use for non-technical users.  For more advanced users, however, there are loads of cool features such as lookup columns, pivot options, and data validation which allow you to create robust data management solutions.

If you know how to use SQL Server Management Studio, the copy and paste feature is a great option when you need to quickly and easily import data from Excel to SQL Server. The process is simple and doesn’t require any special knowledge or tools, and can be used in tables with up to a few tens of thousands of rows of data.  It can also cater for scenarios such as tables with an auto-incrementing identity key, or if you need to connect to SQL Server on a remote machine using a Remote Desktop Connection.

Give yourself a break
Choose the lightweight, quick option that is easy to delegate to business users without risking data integrity or your configurations.

Try SQL Spreads today

Download your free trial of SQL Spreads and get in touch with us if you have any questions.

Try SQL Spreads for free

Try SQL Spreads during 14 days for free. The free trial is the fully
functional, time-limited only product.
Try Excel Add-In for Free download-image
stars-image
14-days Free Trial. No credit card required.