【论坛注册码购买】

QQ登录

只需一步,快速开始

查看: 2774|回复: 0

[[源码/编码]] 宝塔面板安装sqlsrv扩展

[复制链接]

  离线 

UID1

威望:
0 个

魂币:
98886 个

热心:
13692 点

我的勋章
Wgsk作者认证 实名认证 发表于 2022-3-30 18:12:15 | 显示全部楼层 |阅读模式
00529184395.png


环境用的Centos + 宝塔面板,近来一个项目需要用到PHP连接一个远程mssql数据库取一个参数,下面说一下实现方法:

#一、【加入微软的源】
  1. curl https://packages.microsoft.com/config/rhel/7/prod.repo > /etc/yum.repos.d/mssqlrelease.repo
复制代码

当前是安装php7以上的版本,其他版本对应自行到官网查询

如果发现这个链接失效了,可以到https://packages.microsoft.com/config/rhel/7/找下


#二、【安装驱动】
  1. yum install msodbcsql mssql-tools unixODBC-devel
复制代码
安装以上三个驱动,当前是支持php7以上的版本


#三、【下载pdo_sqlsrv扩展包】
  1. wget http://pecl.php.net/get/pdo_sqlsrv-5.8.1.tgz
复制代码

更多版本:http://pecl.php.net/package/pdo_sqlsrv

特别说明:如果在第五步安装时出现报错,请根据更换版本尝试,一般最新版本可行。


#四、【解压并进入目录】
  1. tar -zxvf pdo_sqlsrv-5.8.1.tgz
  2. cd pdo_sqlsrv-5.8.1
复制代码


#五、【执行命令安装】
  1. /www/server/php/73/bin/phpize
  2. ./configure --with-php-config=/www/server/php/73/bin/php-config
  3. make && make install
复制代码
当前为宝塔,路径如下,使用对应php版本的phpize

73代表的是php的版本号,如果你是7.2的。可能是目录就是72

非宝塔环境下,按如下:
  1. /usr/local/php/bin/phpize
  2. ./configure --with-php-config=/usr/local/php/bin/php-config
复制代码

以上仅为通用环境下安装sqlsrv扩展,宝塔环境安装sqlsrv扩展请略过此处按步骤来操作



#六、【加入扩展】
  1. echo "extension = pdo_sqlsrv.so" >> /www/server/php/73/etc/php.ini
  2. /etc/init.d/php-fpm-73 reload
复制代码



#七、【检查扩展是否安装成功】
  1. http://www/server/php/73/bin/php%20-m%7Cgrep%20-i%20%20sqlsrv
复制代码
或者直接去宝塔面板 - 软件管理 - PHP7.3 - phpinfo 查看。



#八、【清理安装包】
  1. cd ..
  2. rm -rf pdo_sqlsrv-5.8.1
  3. rm -rf pdo_sqlsrv-5.8.1.tgz
复制代码



最近附上宝塔面板安装sqlsrv扩展后,PHP连接远程MSSQL函数:

已在如上环境安装后测试通过
  1. function mssql_user($username){
  2.         $host="远程服务器IP,MSSQL端口";
  3.         $dbname="数据库名称";
  4.         $user="数据库用户名";
  5.         $pass="数据库密码";
  6.         try {
  7.             $dbh = new PDO("sqlsrv:Server=$host;Database=$dbname", $user, $pass);
  8.         } catch(PDOException $e) {
  9.             echo $e->getMessage();
  10.             exit;
  11.         }
  12.         $stmt = $dbh->prepare("SELECT XXX FROM XXX WHERE XXX = ".$username);
  13.         $stmt->execute();
  14.         while ($row = $stmt->fetch()) {
  15.                 echo $row[0];//多个查询结果输出
  16.                 //return $row[0]; 单一的结果可以直接用return
  17.         }
  18.         unset($dbh); unset($stmt);
  19. }
复制代码

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|小黑屋|魂影技术论坛 ( 浙ICP备16020365号-1 )|网站地图

GMT+8, 2024-11-21 22:21 , Processed in 0.099698 second(s), 28 queries , Gzip On.

Powered by Discuz! X3.4

© 2001-2017 Comsenz Inc.