Troubleshoot error - Install-Module: Administrator rights are required to install modules in 'C:\Program Files\WindowsPowerShell\Modules.' for SQL Server module.
By default, if we install a PowerShell module, it gets saved in the C:\Program Files\WindowsPowerShell\Modules directory. Recently, in a situation user has limited administrator permission on VM. He could not write to the directory C:\Program Files\WindowsPowerShell\Modules. Therefore, the sqlserver module could not be loaded.
Install-Module SQLServer
It gives the following error message.
data:image/s3,"s3://crabby-images/d9553/d9553121673472236288771d090065b667297a75" alt=""
How do you install the SQLServer module in this case?
Use the following PS script to install and import the module in a specific directory. Here, I specified the directory name as C:\Temp\PSModule. You can modify the path as per your requirements.
if ($env:PSModulePath -notlike "*c:\Temp\PSModule*")
{
if((Get-Item c:\Temp\PSModule -ErrorAction SilentlyContinue ) -eq $null) {
New-Item -Path c:\Temp\PSModule -Name "Modules" -ItemType "directory"
}
$env:PSModulePath += ";c:\Temp\PSModule"
}
Save-Module -Name SqlServer -Path c:\Temp\PSModule
Import-Module -Name sqlserver
It downloads and installs the SqlServer PowerShell module in the specified directory, as shown below.
data:image/s3,"s3://crabby-images/f7f11/f7f11d7ad59aad79c11c940085e5ffaee17c95f9" alt="Verify SqlServer PowerShell module"