在 ubuntu20.0 上安裝/啟用 php8.1 的 sqlsrv 和 pdo_sqlsrv 驅動程式
P粉501683874
P粉501683874 2023-11-01 11:06:13
0
2
921

我正在嘗試在 Ubuntu 20.0 上啟用 php8.1 的 sqlsrv 驅動程式。它沒有在 phpinfo() 中顯示擴展名。

當嘗試使用指令 php -m 檢查 sqlsrv 模組時,輸出如下:

我遵循了以下官方文件:

  • https://learn.microsoft.com/en-us/sql/connect/php/installation-tutorial-linux-mac?view=sql-server-ver16
  • 嘗試在 /etc/php/8.1/apache2/php.ini 中新增副檔名(extension=pdo_sqlsrv.so, extension=sqlsrv.so)

我不確定出了什麼問題,任何建議都會受到讚賞。

The output of phpinfo() for php7.4:
The output of phpinfo() for php8.1:

事情是這樣的:

  • 我的電腦上安裝了 PHP 7.4 和 8.1。
  • sqlsrv 驅動程式適用於 php7.4 版本
  • 嘗試安裝/啟用 php8.1 時,它根本不起作用。

我在這裡缺少什麼?

P粉501683874
P粉501683874

全部回覆(2)
P粉823268006

我可以透過新增以下命令來解決此問題。

pecl install sqlsrv pdo_sqlsrv
printf "; priority=20\nextension=sqlsrv.so\n" > /etc/php/8.1/mods-available/sqlsrv.ini
printf "; priority=30\nextension=pdo_sqlsrv.so\n" > /etc/php/8.1/mods-available/pdo_sqlsrv.ini
phpenmod -v 8.1 sqlsrv pdo_sqlsrv

之後需要重新啟動apache2

P粉193307465

你可以試試這個:

1. switch to php8.1
2. sudo pecl uninstall -r sqlsrv 
3. sudo pecl uninstall -r pdo_sqlsrv 
4. sudo pecl -d php_suffix=7.2 install sqlsrv
5. sudo pecl -d php_suffix=7.2 install pdo_sqlsrv
6. sudo service apache2 restart

請注意,-r, --register-only 不會刪除文件,而只會將軟體包註冊為未安裝。

查看此資源以獲取更多資訊。 https://github.com/microsoft/msphpsql/issues/1145#issuecomment- 649682231

熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板