gpt4 book ai didi

php - 无法将 SQLEXPRESS 与 Laravel 5.6 连接

转载 作者:行者123 更新时间:2023-12-02 14:59:45 25 4
gpt4 key购买 nike

我正在尝试将 Laravel 5.6 连接到我的 SQLEXPRESS。

当我尝试将表从 Laravel 迁移到 SQL 时,出现此错误:

SQLSTATE[08001]: [Microsoft][ODBC Driver 13 for SQL Server]TCPProvider: No connection could be made because the target machine actively refused it. (SQL: select * from sysobjects where type = 'U' and name = migrations)

我已经将 sqlsrv 扩展安装到 php 并对其进行了测试:

<?php
$serverName = "MYNAME\\SQLEXPRESS";

$connectionInfo = array( "Database"=>"Portal", "UID"=>"sa", "PWD"=>"mySecretPwd");
$conn = sqlsrv_connect( $serverName, $connectionInfo);

if( $conn ) {
echo "Connection established.<br />";
}else{
echo "Connection could not be established.<br />";
die( print_r( sqlsrv_errors(), true));
}
?>

连接成功。

我还在 phpinfo() 中看到了扩展;

但是如果使用此设置切换到 Laravel 5.6:

我的环境:

DB_CONNECTION=sqlsrv
DB_HOST=MYNAME\\SQLEXPRESS
DB_PORT=1433
DB_DATABASE=Portal
DB_USERNAME=sa
DB_PASSWORD=mySecredPwd

我的配置/数据库:

'default' => env('DB_CONNECTION', 'sqlsrv'),

'connections' => [

.....

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

],

我遇到了一个错误。我的服务器配置管理器如下所示:

enter image description here

我还可以连接 SQL Server Management Studio 2017。

最佳答案

首先,找到默认实例的端口号:

  • 检查端口号。如果你有 MS SQL Server Management Studio,执行:xp_readerrorlog 0, 1, N'Server is listening on' in master database

  • 带命令提示符(会有很多行,但一定要分析):netstat -ano

可能的解决方案:

  • 停止 SQL Server Browser 服务并再次测试,始终使用端口号。如果它在端口 1433 上运行,您可以使用 TCP/IP 连接到 SQL Server 的默认实例
  • 设置SQL Server不使用动态端口,并设置默认实例的端口号。
  • 更改 Laravel 中的配置/数据库以找到跳过端口号的方法。我没有使用 Laravel 的经验,但我认为您可以尝试使用 'port' => env('DB_PORT', null),

如何配置服务器监听特定端口:

  • 打开“计算机管理\服务\SQL Server 配置管理器”。
  • 展开“SQL Server 网络配置\[实例名称] 的协议(protocol)”并双击“TCP/IP”。在“TCP/IP 属性”对话框的“IP 地址”选项卡上,转到“IPAll”。将“TCP Dynamci 端口”留空。将“TCP 端口”设置为所需的端口号(可以是默认的 1433)。
  • 在“SQL Server 服务”中,双击“SQL Server 浏览器”。在“服务”选项卡中,将“启动模式”设置为“手动”。
  • 在“SQL Server 服务”中,双击“SQL Server 浏览器”。在“登录”中停止服务。
  • 在“SQL Server 服务”中,双击 SQL Server([实例名称])。在“登录”中重新启动服务。
  • 将客户端连接字符串设置为“server\instance,port”格式。

好的起点是: SQL Server Browser ServiceConfigure a Server to Listen on a Specific TCP Port

希望对您有所帮助。

关于php - 无法将 SQLEXPRESS 与 Laravel 5.6 连接,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50624986/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com