php – Laravel到SQL Server(sqlsrv). [PDOException]找不到驱动程序

介绍.我的laravel应用程序使用的是mysql,现在它需要托管在我正在工作的公司的网络中(我是一名远程工作者).这家公司是微软的,所以我需要将laravel集成到他们的SQL Server中.

我的.env中有这个

DB_CONNECTION=sqlsrv
DB_HOST=ip.address.of.server
DB_PORT=3306
DB_DATABASE=my_db
DB_USERNAME=my_username
DB_PASSWORD=my_password

使用php artisan migrate后

错误:

  [PDOException]
  could not find driver

我正在使用Ubuntu,一个专用于我的远程盒子(来自我的雇主).我之前尝试在我的laravel应用程序中使用sql server(使用我的Windows PC).据我记得,我在xampp php.ini中编辑了一些文本.作为一个新手Linux用户,对我来说太难了(因为我只使用CLI).

EDITED(新版本)

所以我已经从Ubuntu连接到数据库服务器了.我使用了sqlcmd -S< host> -U<用户名>

我测试了查询(例如来自users_data的SELECT *)并且它可以工作.

现在,我修改了config / database.php并添加了这个.

'sqlsrv' => [
                'driver'   => 'MSSQL',
                'host'     => env('DB_HOST', 'host.of.the.database'),
                'database' => env('DB_DATABASE', 'my_database'),
                'username' => env('DB_USERNAME', 'my_username'),
                'password' => env('DB_PASSWORD', 'my_pass'),
          'port'     => '1433',
                'prefix'   => '',
            ],

但我得到一个错误:

[InvalidArgumentException]
  Unsupported driver [MSSQL]

“MSSQL”是我用来配置FreeTDS的名称.

解决方法:

对于那些追求的人

确保你使用的PHP版本(对我来说,宅基地目前使用的是php 7.1,所以我安装了php7.1-sybase)

sudo apt-get install freetds-common freetds-bin unixodbc php7.1-sybase

而司机是

'sqlsrv' => [
            'driver' => 'sqlsrv',
            'host' => env('DB_HOST', 'localhost'),
            'database' => env('DB_DATABASE', 'forge'),
            'port' => env('DB_PORT', '1433'),
            'username' => env('DB_USERNAME', 'forge'),
            'password' => env('DB_PASSWORD', ''),
            'charset' => 'utf8',
            'prefix' => '',
        ]

您可以使用tsql确保连接信息正确

TDSVER=8.0 tsql -H Host -U Username -D DatabaseName -p 1433 -P Password
上一篇:java – 使用JDBC从Access数据库读取Unicode数据


下一篇:PHP:调试与Access数据库(.accdb)的PDO连接