在ubuntu

时间:2016-09-09 22:14:38

标签: php sql-server odbc freetds

当尝试连接到我的mssql数据库时,我收到错误     “SQLSTATE [01002] Adaptive Server连接失败(严重级9)”

下面是我正在运行的php代码

<?php

  try {
    $hostname = "hostname.database.windows.net";
    $port = 1433;
    $dbname = "database-dev";
    $username = "dbuser";
    $pw = "dbpassword";   
    $dbh = new PDO     ("dblib:host=$hostname:$port;dbname=$dbname","$username","$pw");
  } catch (PDOException $e) {
    echo "Failed to get DB handle: " . $e->getMessage() . "\n";
    exit;
  }
  $stmt = $dbh->prepare("select name from master..sysdatabases where     name = db_name()");
  $stmt->execute();
  while ($row = $stmt->fetch()) {
    print_r($row);
  }  
  unset($dbh); unset($stmt);
?>

下面是我的odbc.ini,odbcinst.ini和freetds.conf,你可以在这里看到我的phpinfo()(“http://wingedw.com/matiks/connect.php”)驱动程序设置为freetds,pdo和pdo_dlib模块已经添加到PHP 5,任何线索,为什么我得到错误,我确定凭据是正确的。

odbc.ini

[MSSQLServer]
Driver = FreeTDS
Description = Any description
Trace = No
Server = servername
Port = 1433
Database = dbname
wTDS_Verison = 7.1

ODBCINST.INI

[FreeTDS]
Driver      = /usr/lib/i386-linux-gnu/odbc/libtdsodbc.so
Setup           = /usr/lib/i386-linux-gnu/odbc/libtdsS.so
UsageCount      = 1

freetds.conf

[global]
    # TDS protocol version
;       tds version = 7.1

    # Whether to write a TDSDUMP file for diagnostic purposes
    # (setting this to /tmp is insecure on a multi-user system)
;       dump file = /tmp/freetds.log
;       debug flags = 0xffff

    # Command and connection timeouts
;       timeout = 100
;       connect timeout = 100

    # If you get out-of-memory errors, it may mean that your client
    # is trying to allocate a huge buffer for a TEXT field.  
    # Try setting 'text size' to a more reasonable limit 
    text size = 64512

# A typical Sybase server
[egServer50]
    host = symachine.domain.com
    port = 5000
    tds version = 7.1

# A typical Microsoft server
[MSSQLServer]
    host = servername
    port = 1433
    tds version = 7.1

2 个答案:

答案 0 :(得分:0)

事实证明一切都配置正确,问题是使用dblib而不是odbc,请参阅下面的代码。

try {
    $hostname = "hostname.database.windows.net";
    $port = 1433;
    $dbName = "databasename";
    $dbuser = "dbuser@hostname";
    $dbpass = "password";   
$dbh = new PDO('odbc:DRIVER=FreeTDS;SERVERNAME=mssql;DATABASE=' . $dbName,
          $dbuser, $dbpass);
  //echo "COnnected";

  } catch (PDOException $e) {
    echo "Failed to get DB handle: " . $e->getMessage() . "\n";
    exit;
 }

答案 1 :(得分:0)

2021 - 回到未来:

我知道这篇文章很旧,但我的回复可以为一个绝望的灵魂指明正确的方向:

  1. 您正在使用 odbc 并且命令“isql”工作正常
  2. 您正在使用 FreeTDS 并且命令“tsql”工作正常
  3. 运行通过 FreeTDS 调用 odbc 的 php 脚本时出现问题 -> 不断出现错误

请阅读: https://www.linuxquestions.org/questions/blog/tix-592494/freettds-libiodbc-iodbc-php-7-4-21-on-slackware-current-5-13-5-38621/

欢呼快乐的灵魂!