src/SQL/Invoke-XrmSqlCommand.ps1
<#
.SYNOPSIS Connect to TDS endpoint. .DESCRIPTION Specify connection parameters to run SQL commands thru TDS Endpoint. .PARAMETER Command SQL Statement #> function Invoke-XrmSqlCommand { [CmdletBinding()] param ( [Parameter(Mandatory = $true)] [ValidateNotNullOrEmpty()] [String] $Command, [Parameter(Mandatory = $false)] [Switch] $IgnoreDbNull = $false ) begin { $StopWatch = [System.Diagnostics.Stopwatch]::StartNew(); Trace-XrmFunction -Name $MyInvocation.MyCommand.Name -Stage Start -Parameters ($MyInvocation.MyCommand.Parameters); Assert-XrmTdsEndpointEnabled; Assert-XrmTdsEndpointConnected; } process { $userName = $Global:XrmContext.CurrentConnection.UserName; $password = $Global:XrmContext.CurrentConnection.Password; $url = $Global:XrmContext.CurrentInstance.Url; $url = $url.Replace("https://", ""); $url = $url.Remove($url.IndexOf('/')); $connectionString = "Server=$url,5558;Authentication=Active Directory Password;Database=$url;User Id=$userName;Password=$password;"; $connection = new-object System.Data.SqlClient.SQLConnection($connectionString); $cmd = new-object System.Data.SqlClient.SqlCommand($Command, $connection); $connection.Open(); $reader = $cmd.ExecuteReader(); $results = @(); while ($reader.Read()) { $hash = @{}; for ($i = 0; $i -lt $reader.FieldCount; $i++) { $value = $reader.GetValue($i); if ($IgnoreDbNull -and $value -eq [DBNull]::Value) { continue; } $hash[$reader.GetName($i)] = $value; } $results += new-object psobject -property $hash; } $connection.Close(); $results; } end { $StopWatch.Stop(); Trace-XrmFunction -Name $MyInvocation.MyCommand.Name -Stage Stop -StopWatch $StopWatch; } } Export-ModuleMember -Function Invoke-XrmSqlCommand -Alias *; |