安装扩展这部分直接看我的另外一篇文章,地址是:
https://blog.20230611.cn/?id=353
php连接sqlserver方式有4种:
pdo sqlsrv_connect odbc com
前面两种方式会依赖微软给的驱动版本,也依赖于固定版本的sqlserver,例如sqlserver2000只能在php5.3版本使用。而com和odbc不用限制。
例如我的php7.3连接sqlserver2000的代码:
// 连接SQL $sql = iconv('UTF-8', 'GBK', $sql);; $dsn = "Driver={SQL Server};Server={$config['host']};Database={$config['name']};trusted_connection=Yes"; $conn = odbc_connect($dsn, $config['user'], $config['pass'], SQL_CUR_USE_ODBC); if (!$conn) { throw new Exception('连接SQL服务器失败'); } // 执行SQL $result = odbc_exec($conn, $sql); if (!$result) { throw new Exception('SQL执行失败:' . odbc_error()); } // 提取结果 $responseData = []; while (true) { $row = (odbc_fetch_array($result)); if (!$row) { break; } $keys = array_keys($row); foreach ($keys as $key) { $row[$key] = iconv('GBK', 'UTF-8', $row[$key]); } $responseData[] = $row; } odbc_close($conn); return $responseData;
当然也可以使用com连接,具体代码自己搜索,开启com_dotnet.dll即可
$dbConn=new COM ("ADODB.Connection")
com连接的代码和asp是完全一致的,如果你写过asp,看一下绝对完全一致。
要处理编码问题,传递给sqlserver的sql自己转gbk编码,sqlserver返回结果你再转换回utf8即可。
浪费了一天半的时间研究这个东西真不划算,大部分时间卡在了编码问题,还以为是不支持,还好帮朋友解决了问题。
<!doctype html> <html> <head> <meta charset="utf-8"> <title>demo</title> </head> <bod...
在项目中需要对图片进行裁剪,前端裁剪完成发送base64给后端,但是很意外的PHP获取到的数据和前端有点差距,之前我都是先加密,后端解密,但是这次依然不行。于是使用filter_input方法轻松解决。$base64 = filter_input(INPUT_POST...
第一步:服务端文件<?php $wsdlfile='webservice.wsdl'; ini_set('soap.wsdl_cache_enabled','0'); //关闭WSDL缓存 //001...
主要原理是通过PHP创建多个子进程,在子进程中发送进程闹钟信号,然后再监听闹钟信号中继续发送闹钟信号。同时通过父进程设置非阻塞运行。代码如下:<?php /** * 订单任务 */ class Order { &n...
(1).学习目标: 了解常见信号类型(百度PHP支持的信号类型),(2).相关函数学习: (2.1).pcntl_signal函数用于设置一个信号管理器接收进程信号,参数1:信号类型,参数2:回调函数,用于在接收到参数1类型的信...
(1).在PHP中可以查看的环境变量包括: (1.1).电脑环境变量 (2.1).服务器环境变量(2).getenv()函数获取一个环境变量的值.参数1是环境变量的key,参数2值为true的时候仅从你的电脑环境变量中查找,参数2值为false会从两种变量中全部查询//获取我电脑登录的用户名,输出A...