宝塔 PHP7.2 安装pdo_sqlsrv扩展 TP5对接SQLServer数据库

36 篇文章 0 订阅
6 篇文章 0 订阅

前排提示,本教程基于centOS7.6+宝塔最新版本,gcc组件为4.8版本

实测在centOS6.8+宝塔(pytohn2版本)环境下,由于gcc组件是4.4版本,会造成安装失败,请谨慎操作

SQLServer 实际上是 mssql,想要使用 thinkphp 的 Db 对象操作数据库前必须要在服务器上安装对应的扩展。

宝塔面板的 PHP 安装路径为 /www/server/php/ 且支持多个 PHP 版本共存,所以安装 PHP 扩展的方法与网上那些示例略有不同

下面是 PHP7.2 安装 pdo_sqlsrv5.6.0 扩展的过程。( pdo_sqlsrv 扩展目前最新的版本可以通过此网址查看 http://pecl.php.net/package/pdo_sqlsrv

#加入微软的源
curl https://packages.microsoft.com/config/rhel/7/prod.repo > /etc/yum.repos.d/mssqlrelease.repo
 
#安装驱动
yum install -y msodbcsql mssql-tools unixODBC-devel
 
#下载pdo_sqlsrv扩展包
wget http://pecl.php.net/package/pdo_sqlsrv wget http://pecl.php.net/get/pdo_sqlsrv-5.6.0.tgz
tar -zxvf pdo_sqlsrv-5.6.0.tgz
cd pdo_sqlsrv-5.6.0
 
#使用对应php版本的phpize
/www/server/php/72/bin/phpize
./configure --with-php-config=/www/server/php/72/bin/php-config
 
#编译
make && make install
 
#加入扩展
echo "extension = pdo_sqlsrv.so" >> /www/server/php/72/etc/php.ini
 
#重启php7.2
/etc/init.d/php-fpm-72 reload
 
#检查扩展是否安装成功
/www/server/php/72/bin/php -m|grep -i sqlsrv

 TP5 使用 Db 对接 SQLServer 数据库

public function sqltest()
    {
        $sql = 'select * from show_all_student';
        $mssql = Db::connect([
            // 数据库类型
            'type' => 'sqlsrv',
            // 服务器地址
            'hostname' => '10.168.10.75',
            // 数据库名
            'database' => 'test',
            // 数据库用户名
            'username' => 'sa',
            // 数据库密码
            'password' => 'sa',
            // 数据库连接端口
            'hostport' => '1433',
            // 数据库编码默认采用utf8
            'charset' => 'utf8',
        ]);
        $result = $mssql->query($sql);
        dump($result);
    }

 

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
在 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.,则表示连接成功。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值