To get the batches exactly as you want them, you often end up exporting a list of mailboxes to a CSV file and then cutting that down into batches. You can create a batch by importing a CSV file.
To simplify this process, I've created a script that takes all the mailboxes from a list of source databases and generates the CSV files in batch sizes that you specify. For example, you can use both Admin1DB and Admin2DB as your source databases. If you specify a batch size of 200 mailboxes, then you'll get CSV files with 200 mailboxes except for the final CSV which has the left overs.
The script can also automatically create the migration batches if you turn that option on. In the script, you can specify one or more destination mailbox databases for the moves.
The script does not specify an archive database. If your users have archive mailboxes, then you'll need to edit the migration batches after creation and specify the correct databases for the archive mailboxes.
A final note: The script creates the migration batches, but does not start them. Starting the migration batches and the timing of it is up to you.
The script is below. I hope you find it useful.
#This script selects users from existing source mailbox databases
#and creates migration batches to new Mailbox databases
#Typical use is migration projects, but could also be used for
#server retirement or cleaning up corrupted mailbox databases
#Multiple migration batches are created but you need to start them.
#Archive mailboxes are not included when the migration batches are
#created. To move archive mailboxes, edit the migration matches
#after they are created.
#Created by Byron Wright (@ByronWrightGeek)
#Set variables for creating batches
#BatchSize is the number of mailboxes in each batch
$BatchSize=50
#BatchName is text added on to the CSV name and batch name
#This is useful to uniquely identify groups such as
#Admin or Students
$BatchName="Batch"
#Path for CSV files
#This patch must already exist
$CsvPath="C:\Scripts\"
#Mailboxes in the the source mailbox databases that are put into migration batches
#One or more databases can be used
$SourceMbxDB="Mailbox Database 0999986598","VIP Users"
#When $CreateMigrationBatch is $true a migration batch is created from
#each CSV file. If it is $false then only the CSV files are created.
#If $false then you don't need to configure the destination database
$CreateMigrationBatch=$true
#Batches move mailboxes to the destination mailbox databases
#One or more databases can be specified
#When multiple databases are specified, the mailboxes are
#spread among the databases based on number of mailboxes and
#not size of mailboxes.
$DestinationDB="DB1","Mailbox Database 1840440945"
#Get list of mailboxes to move
Foreach ($s in $SourceMbxDB) {
$Mbx+=Get-Mailbox -Database $s
}
$MbxNumber=0
#Add a batch number property to each mailbox
#Add the EmailAddress property to each mailbox as required for the New-MigrationBatch CSV
Foreach ($m in $Mbx) {
$batch=[Math]::Floor(($MbxNumber)/$BatchSize)+1
$m | Add-Member -NotePropertyName Batch -NotePropertyValue $batch
$m | Add-Member -MemberType AliasProperty -Name EmailAddress -Value PrimarySMTPAddress
$mbxNumber++
}
$TotalBatches=[Math]::Floor(($Mbx.count)/$BatchSize)+1
#CreateCSV files and migration batches
For($b=1;$b -le $TotalBatches;$b++) {
$BatchFileName="$BatchName$b.csv"
$BatchPath=$CsvPath+$BatchFileName
$mbx | Where-Object Batch -eq $b | Select-Object Name,EmailAddress,Batch | Export-CSV $BatchPath -NoTypeInformation
If ($CreateMigrationBatch -eq $true) {
New-MigrationBatch -Name $BatchFileName -CSVData ([System.IO.File]::ReadAllBytes(“$BatchPath”)) –Local –TargetDatabase $DestinationDB -AllowUnknownColumnsInCsv $true
}
}