![]() |
VOOZH | about |
The CData Cmdlets for HubSpot are standard PowerShell cmdlets that make it easy to accomplish data cleansing, normalization, backup, and other integration tasks by enabling real-time and bidirectional access to HubSpot.
CData provides the easiest way to access and integrate live data from HubSpot. Customers use CData connectivity to:
Users frequently integrate HubSpot with analytics tools such as Tableau, Power BI, and Excel, and leverage our tools to replicate HubSpot data to databases or data warehouses.
To learn about how other customers are using CData's HubSpot solutions, check out our blog: Drivers in Focus: Simplified HubSpot Connectivity.
The Cmdlets are not only a PowerShell interface to HubSpot, but also an SQL interface; this tutorial shows how to use both to create, retrieve, update, and delete HubSpot data. We also show examples of the ADO.NET equivalent, which is possible with the CData ADO.NET Provider for HubSpot. To access HubSpot data from other .NET applications, like LINQPad, use the CData ADO.NET Provider for HubSpot.
Once you have acquired the necessary connection properties, accessing HubSpot data in PowerShell can be enabled in three steps.
HubSpot uses the OAuth authentication standard. You can use the embedded OAuthClientId, OAuthClientSecret, and CallbackURL or you can obtain your own by registering an app.
See the Getting Started chapter of the help documentation for a guide to using OAuth.
Install the module:
Install-Module HubSpotCmdlets
Connect:
$hubspot = Connect-HubSpot -InitiateOAuth "$InitiateOAuth"
Search for and retrieve data:
$region = "ONTARIO" $prospects = Select-HubSpot -Connection $hubspot -Table "Prospects" -Where "Region = `'$Region`'" $prospects
You can also use the Invoke-HubSpot cmdlet to execute SQL commands:
$prospects = Invoke-HubSpot -Connection $hubspot -Query 'SELECT * FROM Prospects WHERE Region = @Region' -Params @{'@Region'='ONTARIO'}
Load the provider's assembly:
[Reflection.Assembly]::LoadFile("C:\Program Files\CData\CData ADO.NET Provider for HubSpot\lib\System.Data.CData.HubSpot.dll")
Connect to HubSpot:
$conn= New-Object System.Data.CData.HubSpot.HubSpotConnection("InitiateOAuth=GETANDREFRESH;")
$conn.Open()
Instantiate the HubSpotDataAdapter, execute an SQL query, and output the results:
$sql="SELECT Slug, PageViews from Prospects"
$da= New-Object System.Data.CData.HubSpot.HubSpotDataAdapter($sql, $conn)
$dt= New-Object System.Data.DataTable
$da.Fill($dt)
$dt.Rows | foreach {
Write-Host $_.slug $_.pageviews
}
Update-HubSpot -Connection $HubSpot -Columns @('Slug','PageViews') -Values @('MySlug', 'MyPageViews') -Table Prospects -Id "MyId"
$cmd = New-Object System.Data.CData.HubSpot.HubSpotCommand("UPDATE Prospects SET Region='ONTARIO' WHERE Id = @myId", $conn)
$cmd.Parameters.Add((New-Object System.Data.CData.HubSpot.HubSpotParameter("@myId","skycomp-solutions-inc")))
$cmd.ExecuteNonQuery()
Add-HubSpot -Connection $HubSpot -Table Prospects -Columns @("Slug", "PageViews") -Values @("MySlug", "MyPageViews")
$cmd = New-Object System.Data.CData.HubSpot.HubSpotCommand("INSERT INTO Prospects (Region) VALUES (@myRegion)", $conn)
$cmd.Parameters.Add((New-Object System.Data.CData.HubSpot.HubSpotParameter("@myRegion","ONTARIO")))
$cmd.ExecuteNonQuery()
Remove-HubSpot -Connection $HubSpot -Table "Prospects" -Id "MyId"
$cmd = New-Object System.Data.CData.HubSpot.HubSpotCommand("DELETE FROM Prospects WHERE Id=@myId", $conn)
$cmd.Parameters.Add((New-Object System.Data.CData.HubSpot.HubSpotParameter("@myId","skycomp-solutions-inc")))
$cmd.ExecuteNonQuery()
CodeProject
Download a free trial of the HubSpot Data Provider to get started:
Download NowLearn more:
👁 HubSpot IconRapidly create and deploy powerful .NET applications that integrate with HubSpot marketing automation platform including Contacts, Deals, Emails, Companies, and more!