Skip to content

Instantly share code, notes, and snippets.

@teambob
Last active March 31, 2025 07:04

Revisions

  1. teambob revised this gist Mar 31, 2025. 1 changed file with 15 additions and 4 deletions.
    19 changes: 15 additions & 4 deletions odbc.ps1
    Original file line number Diff line number Diff line change
    @@ -1,3 +1,17 @@
    # odbc.ps1
    # Powershell script to run queries against ODBC
    #
    # Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the “Software”), to
    # deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
    # sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
    #
    # The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
    #
    # THE SOFTWARE IS PROVIDED “AS IS”, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
    # FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
    # LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
    # IN THE SOFTWARE.

    if ( $args.Count -lt 2 ) {
    Write( "Usage: odbc.ps1 <DSN> <SQL>")
    Exit(1)
    @@ -12,10 +26,7 @@ $cmd = New-Object System.Data.Odbc.OdbcCommand $sql, $con
    $rdr = $cmd.ExecuteReader()
    while ($rdr.Read())
    {
    for($field = 0; $field -lt $rdr.FieldCount; $field++) {
    Write ($rdr.GetValue($field))
    }
    Write(" ").\odbc
    Write(0..($rdr.FieldCount-1) | foreach-object {$rdr.GetValue($_)} | Join-String -Separator "|")
    }
    $rdr.Close()
    $con.Close()
  2. teambob created this gist Mar 31, 2025.
    21 changes: 21 additions & 0 deletions odbc.ps1
    Original file line number Diff line number Diff line change
    @@ -0,0 +1,21 @@
    if ( $args.Count -lt 2 ) {
    Write( "Usage: odbc.ps1 <DSN> <SQL>")
    Exit(1)
    }

    $connStr = $args[0]

    $con = New-Object System.Data.Odbc.OdbcConnection $connStr
    $con.Open()
    $sql = $args[1]
    $cmd = New-Object System.Data.Odbc.OdbcCommand $sql, $con
    $rdr = $cmd.ExecuteReader()
    while ($rdr.Read())
    {
    for($field = 0; $field -lt $rdr.FieldCount; $field++) {
    Write ($rdr.GetValue($field))
    }
    Write(" ").\odbc
    }
    $rdr.Close()
    $con.Close()