Move mailboxes (in bulk) or one by one to another database in Exchange 2010/2013/2016

Published on
17,651 Points
Last Modified:
Exchange Server, Windows Server, Active Directory, Virtualization, Skype for Business Expert.
A method of moving multiple mailboxes (in bulk) to another database in an Exchange 2010/2013/2016 environment...

There are often cases where administrators may need to merge two mailbox databases to one, or move all mailboxes to other mailboxdatabase or move mailboxes after installing new version of Exchange.

Questions about this process have been frequently popping up at Experts Exchange of late, so I've decided to write an article explaining how to move Microsoft Exchange mailboxes in a bulk or one bye one fashion, thus saving a lot of time.

First, let's view all the mailboxes in the database using the following command;

Get-Mailbox -Database Mailboxdb02

Now let's try to move in bulk. Mailboxdb02 is the old database name and Mailboxdb01 is the new database name.

Get-Mailbox -Database Mailboxdb02 | New-MoveRequest - TargetDatabase Mailboxdb01 -BatchName "Mailboxdb02to01"

Now there are cases server memory is not enough (or low bandwidth between servers) to move multiple move request at a time. You can use the below script/command. This will create a move request and monitor the move request every 3 minutes, Once complete it will start the next move request.

foreach ($i in (Get-Mailbox -ResultSize unlimited)) { New-MoveRequest -identity $i -TargetDatabase "TargetDatabaseName" -baditemlimit 50 -acceptlargedataloss ;while ((Get-Moverequest -Identity $i | ? {$_.Status -eq “Queued” -or $_.Status -eq “InProgress”})) { sleep 180 } }

Now lets move the system mailboxes to the new database or server. Lets check system mailboxes.

Get-Mailbox -Database "Mailboxdb02" -Arbitration

Next command will move the system/arbitration mailboxes to Mailboxdb01.

Get-Mailbox -Database "MailboxDatabase-Users" -Arbitration | New-MoveRequest -TargetDatabase "MailboxDB01"

Let's check on the progress. You can also set, suspend, remove, resume, and Get-MoveRequestStatistics where we are going to use the last one next.


What we can do instead, is use piping the Get-MorvRequest and Get-MoveRequestStaticstics. Remember, this will not only display just this last jump if previous jobs are not removed after completion.

Get-MoveRequest | Get-MoveRequestStaticstics

Now let's remove MoveRequest by issuing the following command if all move request is completed:

Get-MoveRequest | Remove-MoveRequest

Let's run Get-MoveRequest again to verify that nothing shows up.

Now all your mailboxes have been moved to a different database.

To get additional support on this process, I encourage you to use the Ask a Question feature at Experts Exchange.

If you found this helpful, please click the Thumbs Up button below and please do share any comments below.

Author: MAS - EE MVE

1 Comment

Expert Comment

by:Yoga Rukmantara

thanks for the tutorial...by the way i already succeeded moving the mailbox to another database, but when i try to confirm again using "Get-MailboxDatabase -identity "DBNAME" | Get-MailboxStatistics | sort -property totalitemsize | ft displayname,totalitemsize", i still got the mailbox which i was move before still listed n the old database. is the mailbox just copied to new database ?
maybe  there is any script or command to some kind refresh the list or something like that?

best regards,

Featured Post

Maximize Customer Retention with Superior Service

The IT Service Excellence Tool Kit delivers expert advice for technology solution providers. Get your free copy for valuable how-to assets including sample agreements, checklists, flowcharts, and more to help build customer satisfaction and retention.

In this video, Percona Solution Engineer Rick Golba discuss how (and why) you implement high availability in a database environment. To discuss how Percona Consulting can help with your design and architecture needs for your database and infrastr…
With just a little bit of  SQL and VBA, many doors open to cool things like synchronize a list box to display data relevant to other information on a form.  If you have never written code or looked at an SQL statement before, no problem! ...  give i…

Keep in touch with Experts Exchange

Tech news and trends delivered to your inbox every month