On 28/06/2012 17:07, Shrenuj Bansal wrote:
I am using a perl script to try to connect to SQL Server on Windows. I believe 
I have DBI v1.607 and DBD::ODBC v1.25. I am able to connect to the server when 
I set up a data source using the ODBC Data Source Administrator on Windows. 
However, when I try to set up the data source myself in the perl script with 
the same credentials I get an error. I was hoping someone could help me out 
with this.

Here's my code:


use DBI;

# DBD::ODBC

my $dsn = 'DBI:ODBC:Driver={SQL Server}';
my $host =
my $database =
my $user =
my $auth =

# Connect via DBD:ODBC by specifying the DSN dynamically
my $dbh = DBI->connect("$dsn;Server=$host;Database=$database",
                                                $user,
                                                $auth,
                                                { RaiseError => 1, AutoCommit 
=> 1}
                                                ) || die "Database connection not 
made: $DBI:errstr";
                                                
# Prepare a SQL statement

my $sql = "SELECT BundleVersionLocation FROM valdb.dbo.VDB_BundleVersions WHERE 
BundleVersionID = 20";
my $sth = $dbh->prepare( $sql );

# Execute the statement
$sth->execute();

my($BundleVersionID);

# Bind the results to the local variables
$sth->bind_columns( undef, \$BundleVersionID );

# Retrieve values from the result set
while( $sth->fetch() ) {
        print "$BundleVersionID\n";
}

# Close the connection
$sth->finish();
$dbh->disconnect();

Here is the error I receive when I try to run the above script:

DBI connect('Driver={SQL Server};Server=ecmdrvdev-dbsql;Database=valdb','shrenuj
b',...) failed: [Microsoft][ODBC SQL Server Driver][SQL Server]Login failed for
user 'shrenujb'. (SQL-28000) at test.pl line 13

You did not specify a UID/PWD in the above Perl and yet the error indicates you did specify a username! If you want to use a trusted connection you'll need to add that attribute to the connection string.

You can use dbi:ODBC:DSN=mydsn to connect in Perl where mydsn is the data source you created in the ODBC administrator and then once you connect print out odbc_out_connect_string (http://search.cpan.org/~mjevans/DBD-ODBC-1.37/ODBC.pm#odbc_out_connect_string) and that will be the connection string you need to use to reconnect without a DSN once you replace DSN with DRIVER=xxx (you get this string from the ODBC administrator driver tab and enclose it in {} if it contains spaces).

e.g. (on windows so quotes different),

C:\Users\martin>perl -le "use DBI;my $h = DBI->connect('dbi:ODBC:DSN=asus2','xx'
,'yy'); print $h->{odbc_out_connect_string};"
DSN=asus2;UID=xx;PWD=yy;WSID=ASUS2;DATABASE=master;Network=DBMSSOCN;Address=ASUS2\SQLEXPRESS,1433

Replace DSN=asus2 with DRIVER={SQL Server} (or SQLNative Client or SQL Server Native Client 10.0 depending on what the Drivers tab says).

NOTE: If you put the db username/password in the connection string via UID=xx;PWD=yy the username/password passed to DBI's connect method are ignored - I think (and I say I think because you are using a pretty old DBD::ODBC).

Martin



Reply via email to