php7.3.4连接sqlserver(linux平台)

前言

有个项目需要手上laravel连接客户的sqlserver数据库读取数据,故在docker运行的php容器,需要增加扩展。

过程

容器是基于debian11

1.通过 curl 下载 Microsoft 的 GPG 密钥,并通过 apt-key add 添加到系统密钥链中,以便后续能够验证从 Microsoft 软件包库下载的软件包。

bash 复制代码
curl https://packages.microsoft.com/keys/microsoft.asc | apt-key add -

如果报错gnupg, gnupg2 and gnupg1 do not seem to be installed, but one of them is required for this operation 就先执行这段(因为缺少 gnupg 相关的软件包。使用命令安装 gnupg2)

bash 复制代码
apt-get update && apt-get install -y gnupg2 

2.选择合适的版本安装mssql-release.list

bash 复制代码
#Debian 8
curl https://packages.microsoft.com/config/debian/8/prod.list > /etc/apt/sources.list.d/mssql-release.list

#Debian 9
curl https://packages.microsoft.com/config/debian/9/prod.list > /etc/apt/sources.list.d/mssql-release.list

#Debian 10
curl https://packages.microsoft.com/config/debian/10/prod.list > /etc/apt/sources.list.d/mssql-release.list

3.安装各种依赖

bash 复制代码
#更新系统的软件包列表,以包括新添加的 Microsoft 软件包源。
ACCEPT_EULA=Y apt-get install msodbcsql17
#安装 Microsoft ODBC 驱动程序,接受 EULA 条款。
ACCEPT_EULA=Y apt-get install mssql-tools
#安装 Microsoft SQL Server 相关的工具,如 bcp 和 sqlcmd&配置环境变量
echo 'export PATH="$PATH:/opt/mssql-tools/bin"' >> ~/.bash_profile
echo 'export PATH="$PATH:/opt/mssql-tools/bin"' >> ~/.bashrc
source ~/.bashrc
#添加 Microsoft 工具的路径到用户的 .bash_profile 和 .bashrc 文件,并立即应用这些变更。
apt-get install unixodbc-dev
# apt-get install libgssapi-krb5-2
apt-get install libgssapi-krb5-2

4.安装sqlServer php扩展

bash 复制代码
apt-get -y install unixodbc-dev
pecl install sqlsrv-5.9.0 && pecl install pdo_sqlsrv-5.9.0
tar zxvf sqlsrv-5.9.0.tgz && tar zxvf pdo_sqlsrv-5.9.0.tgz
mv sqlsrv-5.9.0 /usr/src/php/ext/sqlsrv && mv pdo_sqlsrv-5.9.0 /usr/src/php/ext/pdo_sqlsrv
docker-php-ext-install sqlsrv && docker-php-ext-install pdo_sqlsrv

使用larave连接

因为项目已经使用了mysql,希望的效果是不影响原数据

  1. .env写入配置
bash 复制代码
SRV_CONNECTION=sqlsrv
SRV_DB_HOST=192.168.1.1
SRV_DB_PORT=1433
SRV_DB_DATABASE=test_sqldb
SRV_DB_USERNAME=sa
SRV_DB_PASSWORD=123456

2.database.php修改

bash 复制代码
'sqlsrv' => [
	'driver' => 'sqlsrv',
	'host' => env('SRV_DB_HOST', 'localhost'),
	'port' => env('SRV_DB_PORT', '1433'),
	'database' => env('SRV_DB_DATABASE', 'forge'),
	'username' => env('SRV_DB_USERNAME', 'forge'),
	'password' => env('SRV_DB_PASSWORD', ''),
	'charset' => 'utf8',
	'prefix' => '',
	'prefix_indexes' => true,
],

3.代码内使用

bash 复制代码
// 使用默认的 MySQL 连接
//$users = DB::table('users')->get();

// 使用 SQL Server 连接
$sqlServerUsers = DB::connection('sqlsrv')->table('dbo.user')->get()->toArray();
相关推荐
盖世英雄酱581366 分钟前
🚀不改SQL,也能让SQL的执行效率提升100倍
java·数据库·后端
Arrtoria17 分钟前
Kernel2.X的内存世界
linux
程序员岳焱18 分钟前
Java 与 MySQL 性能优化:Linux服务器上MySQL性能指标解读与监控方法
linux·后端·mysql
Jooolin18 分钟前
【编程史】Ubuntu到底是啥?它和Linux又是什么关系?
linux·ubuntu·操作系统
Xy91018 分钟前
从代码角度拆解Apptrace的一键拉起
javascript·数据库
苏州向日葵2 小时前
virtualBox安装ubuntu,常用知识点
linux·运维·ubuntu
袋鼠云数栈2 小时前
国产数据库StarRocks在数栈轻量化数据开发的全流程实践
数据库
Listennnn2 小时前
Text2SQL、Text2API基础
数据库·人工智能
夜光小兔纸2 小时前
SQL Server 修改数据库名及物理数据文件名
运维·数据库·sql server
····懂···3 小时前
数据库专家 OCP 认证培训:开启职业黄金赛道
数据库·oracle·ocp