宝塔linux面板+php7.4安装pdo_sqlsrv和sqlsrv扩展包 sqlserver数据库 报错

第一步:安装odbc驱动程序

curl https://packages.microsoft.com/config/rhel/7/prod.repo | sudo tee /etc/yum.repos.d/mssql-release.repo
sudo yum remove unixODBC-utf16 unixODBC-utf16-devel #to avoid conflicts
sudo ACCEPT_EULA=Y yum install msodbcsql
# optional: for bcp and sqlcmd
sudo ACCEPT_EULA=Y yum install mssql-tools
echo 'export PATH="$PATH:/opt/mssql-tools/bin"' >> ~/.bashrc
source ~/.bashrc
# optional: for unixODBC development headers
sudo yum install unixODBC-devel

报错:needed by msodbcsql-13.1.9.2-1.x86_64,

尝试rpm手动脱机安装

sudo yum install glibc e2fsprogs krb5-libs openssl unixODBC unixODBC-devel #install dependencies
sudo rpm -i  msodbcsql-13.1.X.X-X.x86_64.rpm #install the Driver

msodbcsql-13.1不行,装msodbcsql17可能new  pdo的时候报502错误,排查系统是openeuler,在centos7.9上测试是可以安装msodbcsql-13.1的

#RHEL 7 and Oracle Linux 7
curl https://packages.microsoft.com/config/rhel/7/prod.repo | sudo tee /etc/yum.repos.d/mssql-release.repo

sudo yum remove unixODBC-utf16 unixODBC-utf16-devel #to avoid conflicts
sudo ACCEPT_EULA=Y yum install -y msodbcsql17
# optional: for bcp and sqlcmd
sudo ACCEPT_EULA=Y yum install -y mssql-tools
echo 'export PATH="$PATH:/opt/mssql-tools/bin"' >> ~/.bashrc
source ~/.bashrc
# optional: for unixODBC development headers
sudo yum install -y unixODBC-devel

第二步:安装php7.4对应的pdo_sqlsrv扩展包

wget http://pecl.php.net/get/sqlsrv-5.10.1.tgz
tar -zxvf sqlsrv-5.10.1.tgz
cd sqlsrv-5.10.1
/www/server/php/74/bin/phpize
./configure --with-php-config=/www/server/php/74/bin/php-config
make && make install
echo "extension = sqlsrv.so" >> /www/server/php/74/etc/php.ini

重启
php-fpm

  • 9
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Linux 的 Docker 容器中已有 PHP 环境的情况下,可以通过在容器中安装 MSSQL 驱动程序以及 pdo_sqlsrvsqlsrv 两个扩展来连接 SQL Server 数据库。以下是安装步骤: 1. 进入容器 执行以下命令进入容器: ``` docker exec -it container_name /bin/bash ``` 其中 container_name 是容器的名称或 ID。 2. 安装必要的依赖项 在容器中执行以下命令安装必要的依赖项: ``` apt-get update apt-get install -y \ unixodbc-dev \ gnupg2 \ curl ``` 3. 添加 Microsoft 的存储库并安装 MSSQL 驱动程序 在容器中执行以下命令添加 Microsoft 的存储库并安装 MSSQL 驱动程序: ``` curl https://packages.microsoft.com/keys/microsoft.asc | apt-key add - curl https://packages.microsoft.com/config/debian/10/prod.list > /etc/apt/sources.list.d/mssql-release.list apt-get update ACCEPT_EULA=Y apt-get install -y \ msodbcsql17 \ mssql-tools \ libgssapi-krb5-2 ``` 4. 安装 pdo_sqlsrvsqlsrv 扩展 在容器中执行以下命令安装 pdo_sqlsrvsqlsrv 扩展: ``` pecl install pdo_sqlsrv sqlsrv docker-php-ext-enable pdo_sqlsrv sqlsrv ``` 5. 重启 Apache 服务 在容器中执行以下命令重启 Apache 服务: ``` apachectl -k restart ``` 6. 测试连接 SQL Server 数据库PHP 代码中使用如下方式连接 SQL Server 数据库: ```php $serverName = "your_server_name"; // SQL Server 服务器名称 $connectionOptions = array( "Database" => "your_database_name", // 数据库名称 "Uid" => "your_username", // 用户名 "PWD" => "your_password" // 密码 ); // 创建连接 $conn = sqlsrv_connect($serverName, $connectionOptions); // 检查连接是否成功 if ($conn === false) { die(print_r(sqlsrv_errors(), true)); } else { echo "Connected successfully."; } // 关闭连接 sqlsrv_close($conn); ``` 如果运行结果输出 Connected successfully.,则表示连接成功。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值