windows10 php8连接sql server

news2024/12/24 21:15:54

一、环境安装

文章目录

  • 一、环境安装
    • 1.安装php拓展
    • 2.在 Windows 上安装PHP驱动程序
    • 3.在 Windows 上安装ODBC驱动
  • 二、php连接sqlserver
  • 三、注意事项
    • 数据库相关设置
    • 相关语法
      • `sqlsrv_fetch_array` 的示例:
      • `sqlsrv_fetch` 的示例:
      • echo 和 print_r 的不同

所用资源:

1.安装php拓展

msphpsql-github仓库(较新)

微软-下载 Microsoft Drivers for PHP for SQL Server(稳定)

Microsoft Drivers for PHP for Microsoft SQL Server 是 PHP 扩展,允许从 PHP 脚本中读取和写入 SQL Server 数据。SQLSRV 扩展提供过程接口,而 PDO_SQLSRV 扩展实现 PHP 数据对象 (PDO),用于访问 SQL Server 2012 及更高版本(包括 Azure SQL DB)的所有版本中的数据。这些驱动程序依赖于 Microsoft ODBC Driver for SQL Server 来处理与 SQL Server 的低级别通信。

此版本包含用于 PHP 8.0+ 的 SQLSRV 和 PDO_SQLSRV 驱动程序,并改进了这两个驱动程序并限制了一些限制。即将发布的版本将包含其他功能、错误修复等。

2.在 Windows 上安装PHP驱动程序

驱动程序作为 PHP 的预编译扩展分发,可在发布页面上找到。它们提供线程安全版本和非线程安全版本,以及 32 位(仅限 Windows)和 64 位版本。驱动程序的源代码也可用,您可以将它们编译为线程安全或非线程安全版本。Web 服务器的线程安全配置将决定您需要的版本。

如果选择构建驱动程序,则必须能够在不包含这些扩展的情况下构建 PHP 8.*。有关在 Windows 上构建 PHP 的帮助,请参阅官方 PHP 网站。有关编译驱动程序的详细信息,请参阅文档 – 提供了示例构建脚本,但您也可以手动编译驱动程序。

要加载驱动程序,请确保驱动程序位于 PHP 扩展目录中,并通过向 ini 文件添加和/或在 PHP 安装的 php.ini 文件中启用它。如有必要,请使用 指定扩展目录,例如:。请注意,预编译的二进制文件具有不同的名称 - 在php.ini中相应地替换。有关加载驱动程序的更多详细信息,请参阅 Microsoft Docs 上的加载 PHP SQL 驱动程序。

最后,如果在 Web 服务器中运行 PHP,请重新启动 Web 服务器。

在版本中选择适合的版本(PHP Version 8.3.0)

在这里插入图片描述

在这里插入图片描述

下载好后,选择64位ts(我安装的线程安全版本,nts为非线程安全版本)的两个dll文件,复制到php的根目录,同时修改php.ini

extension=php_pdo_sqlsrv.dll
extension=php_sqlsrv.dll

[MSSQL]
mssql.allow_persistent=On
mssql.max_persistent=-1
mssql.max_links=-1
mssql.min_error_severity=10
mssql.min_message_severity=10
mssql.compatability_mode=Off
mssql.secure_connection=Off

3.在 Windows 上安装ODBC驱动

微软-下载 ODBC Driver for SQL Server

根据电脑系统选择对应版本

在这里插入图片描述

下载后一直下一步默认安装即可。

重启Apache服务

在这里插入图片描述

查看phpinfo页面

然后搜索sqlsrv,如果能搜到,代表sqlserver扩展安装成功

在这里插入图片描述

搜不到代表安装失败,自行检查失败原因及是否遗漏流程步骤

二、php连接sqlserver

可参考官方提供的例子如何:使用 Windows 身份验证进行连接以及如何:使用 SQL Server 身份验证进行连接

<?php  

/* 指定服务器和连接字符串属性
在这里,代码指定了要连接的服务器名称为本地"DESKTOP-UC9IGKA\SQLEXPRESS"
并且设置了连接字符串的属性
其中包括要连接的数据库为RGB*/  

$serverName = "DESKTOP-UC9IGKA\SQLEXPRESS";  
//乱码的话,charset改成UTF-8则php输出正常
$connectionInfo = array( "Database"=>"RGB","CharacterSet" => "UTF-8","Encrypt"=>"false","trustServerCertificate"=>"true");  
  
/*使用Windows身份验证进行连接
如果连接失败,将输出错误信息并中止程序。*/  
$conn = sqlsrv_connect( $serverName, $connectionInfo);  
if( $conn === false )  
{  
     echo "Unable to connect.</br>";  
     die( print_r( sqlsrv_errors(), true));  
}  
  
/* 查询用户登录信息:这里定义了一个查询($tsql)
目的是获取当前用户的登录名。
如果查询执行失败,同样会输出错误信息并中止程序。*/  

$tsql = "SELECT CONVERT(varchar(32), SUSER_SNAME())";  
$stmt = sqlsrv_query( $conn, $tsql);  
if( $stmt === false )  
{  
     echo "Error in executing query.</br>";  
     die( print_r( sqlsrv_errors(), true));  
}  
  
/*检索和显示查询结果:
通过 sqlsrv_fetch_array 函数从查询结果集(stmt,SQL 查询的语句句柄(statement handle))中获取一行数据
然后输出用户登录名
这里假设查询只返回一个字段
因此使用 $row[0] 获取该字段的值 */  
$row = sqlsrv_fetch_array($stmt);  
echo "User login: ".$row[0]."</br>";  
  
/*释放查询语句和数据库连接所占用的资源,以防止资源泄漏。*/  
sqlsrv_free_stmt( $stmt);  
sqlsrv_close( $conn);  
?>

三、注意事项

数据库相关设置

如果使用 NT AUTHORITY/SYSTEM无法登录数据库的话,只需要 在登录名下NT AUTHORITY/SYSTEM右键属性,用户映射-勾选要访问的数据库就可以了,角色成员选 db_owner,public。

在这里插入图片描述

记得取消 阻止保存要求重新创建表的更改

相关语法

38行

sqlsrv_fetch_array 的示例:

sqlsrv_fetch_array 是一个 PHP 函数,用于从结果集中获取一行作为关联数组或数字数组。

while ( $re = sqlsrv_fetch_array($stmt)) { 
	print_r($re);
	echo "</br>";
}

解释如下:

  • $row = sqlsrv_fetch_array($stmt);: 使用 sqlsrv_fetch_array 函数从执行查询的结果集中获取一行数据,并将该行数据存储在关联数组和数字数组中。在这里,由于没有指定关联数组或数字数组,所以默认返回两者兼具的数组。

  • echo "User login: ".$row[0]."</br>";: 输出从结果集中获取的数据。在这里,假设查询返回的结果集只包含一个字段,因此使用 $row[0] 来获取该字段的值,并将其输出到页面上。

总体而言,sqlsrv_fetch_array 的作用是将查询结果集的当前行移动到下一行,并将该行数据存储在数组中,以便后续处理。在这个例子中,通过 echo 语句将用户登录名输出到页面上。

两者兼具的数组

在这里插入图片描述

关联数组

在这里插入图片描述

如果只需要获取查询结果中的值而不需要关联数组的列名或数字数组的序号,可以使用 sqlsrv_fetch 函数。该函数返回一个布尔值,表示是否成功获取下一行的数据。

sqlsrv_fetch 的示例:

while(sqlsrv_fetch($stmt)) {
    print_r(sqlsrv_get_field($stmt, 0)."</br>";);
}

在这个示例中,使用 sqlsrv_fetch 函数尝试获取结果集的下一行数据。如果成功获取了下一行数据,则使用 sqlsrv_get_field 函数直接输出用户登录名的值。sqlsrv_get_field($stmt, 0) 表示获取结果集中第一个字段的值。

请注意,使用 sqlsrv_fetch 后,可以多次调用 sqlsrv_get_field($stmt, index) 来获取不同字段的值,其中 index 为字段的索引。这种方式避免了创建数组,并直接获取所需的值,例如

while(sqlsrv_fetch($stmt)) {
    $output = sqlsrv_get_field($stmt, 0) . sqlsrv_get_field($stmt, 1) . sqlsrv_get_field($stmt, 2) . "</br>";
    print_r($output);
}

在这里插入图片描述

echo 和 print_r 的不同

print_r 是一个用于打印变量的函数,它接受一个变量作为参数,并以可读性更好的格式输出变量的信息。在你的代码中,print_r($re) 用于输出 $re 变量的内容,而 echo "</br>"; 则用于输出一个换行。

然而,当你尝试使用 print_r($re."</br>");echo($re."</br>"); 时,会导致错误,原因如下:

  1. 字符串连接错误: 在这两个语句中,你尝试将 $re 变量与 "</br>" 字符串直接连接起来。然而,$re 可能是一个资源类型(数据库查询结果集的句柄),而不是一个字符串。直接将一个资源与字符串连接可能导致类型不匹配的错误。

  2. echo 和 print_r 的不同: echoprint_r 在处理变量输出时有一些差异。echo 是一个语言结构,可以接受多个参数,用逗号分隔,而 print_r 是一个函数,只接受一个参数。在使用 echo 时,尝试将多个参数直接连接可能导致语法错误。

如果你想在输出中包含 "</br>",你可以在 print_recho 之前将其作为字符串拼接到变量中,如下所示:

// 使用点号连接字符串和变量
echo print_r($re, true) . "</br>";

// 或者使用逗号分隔多个参数
echo print_r($re, true), "</br>";

在上述代码中,print_r($re, true) 返回 $re 的字符串表示,然后使用点号或逗号将其与 "</br>" 字符串连接。确保使用 true 作为 print_r 函数的第二个参数,以便它返回结果而不直接输出。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1315634.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

抠图软件哪个好用?什么软件可以抠图换背景?

抠图软件哪个好用&#xff1f;在图片处理中&#xff0c;抠图换背景是一项常见的操作。很多新手可能会对此感到困惑&#xff0c;不知道应该使用什么软件来进行抠图换景。实际上&#xff0c;现在市面上有很多图片处理软件都具备抠图换背景的功能&#xff0c;每款软件都有其优缺点…

王世军:铁笔翰墨染丹青 九峰冠华传千古

鸡是十二生肖中一员&#xff0c;在民间过年时常被剪成窗花&#xff0c;贴于窗户大门上。为表达人们对鸡的喜爱&#xff0c;将正月初一定为“鸡日”&#xff0c;鸡谐音“吉”&#xff0c;意为大吉大利&#xff0c;讨个好彩头。鸡又为“五德之君”&#xff0c;鸡的五德谓之文、武…

前端基础——鼠标事件对象属性和方法

button:0(未按下)1(左键)2(右键)4(中键) clientX/clientY(表示事件在客户端区域的水平和垂直坐标,左上为原点) ctrlKey表示鼠标事件发生时是否按下了ctrl键 MouseEvent.offsetX和MouseEvent.offsetY表示鼠标相对于目标节点内部填充区域的偏移量 MouseEvent.screenX和MouseE…

终端安全管理软件安装详细攻略来了

随着信息技术的不断发展&#xff0c;终端安全管理软件在企业和组织中发挥着越来越重要的作用。为了确保终端设备的安全和稳定运行&#xff0c;安装终端安全管理软件是必不可少的。以下是一份终端安全管理软件的安装详细攻略&#xff0c;供大家参考。 一、选择合适的软件 首先&…

空洞文件读取空洞部分的返回值

在空洞文件中&#xff0c;未显式写入的部分被称为"空洞"。当读取空洞部分时&#xff0c;系统会返回字节值为0的数据。 这意味着&#xff0c;当你在空洞文件中读取一个偏移量处的数据&#xff0c;而该偏移量位于空洞部分时&#xff0c;读取操作将返回一个全是0的字节…

2023/12/12作业

思维导图 作业&#xff1a; 成果图 代码 #include "widget.h" #include "ui_widget.h" Widget::Widget(QWidget *parent) : QWidget(parent) , ui(new Ui::Widget) { speechernew QTextToSpeech(this); ui->setupUi(this); //一直获取当前时间 idst…

带你学C语言~指针(1)

Hello,CSDN的各位家人们&#xff0c;你们好啊&#xff01;今天&#xff0c;小赵要给大家分享的C语言知识是指针&#xff0c;相信不少家人们都或多或少被指针搞得晕头转向&#xff0c;小赵一开始也是&#xff0c;但后来小赵经过不断地努力学习&#xff0c;终于将这里面的知识弄懂…

【Anaconda】Ubuntu anaconda使用(新建环境、最小化安装Tensorflow, CUDA对应关系)

Ubuntu anaconda使用&#xff08;新建环境、最小化安装Tensorflow&#xff09; 文章目录 Ubuntu anaconda使用&#xff08;新建环境、最小化安装Tensorflow&#xff09;使用conda打包虚拟环境查看已创建的环境删除虚拟环境命令下运行.ipynb文件 清华源地址&#xff1a; https:…

Postman中参数填写方式

Postman中参数填写和请求方法有关&#xff0c;一般接口用例请求方法GET与POST常用&#xff0c;所以主要是这两种请求方法请求参数填写 一、GET请求方法参数填写 1、直接在URL中填写请求参数,如直接在URL中填写&#xff1a; http://www.example.com:8089/userapi?unamelisi&…

Java医院3D人体智能导诊系统源码 Uniapp+springboot 微信小程序

“智能导诊”以人工智能手段为依托&#xff0c;为人们提供智能分诊、问病信息等服务&#xff0c;在一定程度上满足了人们自我健康管理、精准挂号等需求。智能导诊可根据描述的部位和病症&#xff0c;给出适合病症的科室参考。 智能导诊页面会显示男性或女性的身体结构图&#x…

Python读写arxml文件

文章目录 前言一、XML简介二、XML文件结构三、Python读取xml文件安装ElementTree库读取xml文件四、Python写入xml文件前言 本文主要通过介绍arxml文件,为后续python脚本开发奠定基础。 arxml是AUTOSAR XML的简称,是一个通用的配置/数据库文件,实质是一个xml文件。 ①更规范…

机械设备企业网站建设的效果如何

机械设备涵盖的类目比较广&#xff0c;其市场需求也是稳增不减&#xff0c;也因此无论大小企业都有增长的机会&#xff0c;当然这也需要靠谱的工具及正确的决策。 对机械设备企业来说&#xff0c;产品品质自然是首位&#xff0c;而向外打造品牌、扩展信息及拓客转化自然也是非…

HTML5+CSS3+JS小实例:自适应瀑布流布局

实例:自适应瀑布流布局 技术栈:HTML+CSS+JS 效果: 源码: 【HTML】 <!DOCTYPE html> <html><head><meta http-equiv="content-type" content="text/html; charset=utf-8"><meta name="viewport" content=&quo…

深入学习《大学计算机》系列之第1章 1.2节——问题描述与抽象

一.欢迎来到我的酒馆 第1章 1.2节&#xff0c;问题描述与抽象。 目录 一.欢迎来到我的酒馆二.问题描述、抽象与建模1.什么是抽象2.为什么要抽象3.什么是建模4.建什么模 三.面向计算机的问题分析四.总结 二.问题描述、抽象与建模 什么是抽象&#xff1f;为什么要抽象&#xff1f…

用EnumSet代替位域

在Java中&#xff0c;可以使用EnumSet来代替位域&#xff0c;以提高代码的可读性和类型安全性。下面是一个简单的例子&#xff0c;演示如何使用EnumSet来管理一组枚举值&#xff1a; import java.util.EnumSet;// 定义一个枚举类型表示权限 enum Permission {READ, WRITE, EXE…

利用canvas封装录像时间轴拖动(uniapp),封装上传uniapp插件市场

gitee项目地址,项目是一个空项目,其中包含了封装的插件,自己阅读,由于利用了canvas所以在使用中暂不支持.nvue,待优化; 项目也是借鉴了github上的一个项目,timeline-canvas,​​​​​​​ ​​​​​​​

【Hive】【Hadoop】工作中常操作的笔记-随时添加

文章目录 1、Hive 复制一个表:2、字段级操作3、hdfs 文件统计 1、Hive 复制一个表: 直接Copy文件 create table new_table like table_name;hdfs dfs -get /apps/hive/warehouse/ods.db/table_nameload data local inpath /路径 into table new_table;修复表&#xff1a; m…

[pasecactf_2019]flask_ssti proc ssti config

其实这个很简单 Linux的/proc/self/学习-CSDN博客 首先ssti 直接fenjing一把锁了 这里被加密后 存储在 config中了 然后我们去config中查看即可 {{config}} 可以获取到flag的值 -M7\x10wd94\x02!-\x0eL\x0c;\x07(DKO\r\x17!2R4\x02\rO\x0bsT#-\x1cZ\x1dG然后就可以写代码解…

数据结构 | 查漏补缺之顺式存储和链式存储、如何评价哈希函数的好坏、链地址法、树的遍历、关键路径、完全图、连通图、迪杰斯特拉、b树

目录 顺式存储和链式存储 优缺点比较 顺序存储 ​编辑 链式存储 如何评价哈希函数的好坏 简述哈希查找中链地址法解决冲突的方法 树的遍历 关键路径 完全图 连通图 迪杰斯特拉 b树 特点&#xff1a; 插入&#xff08;索引不能大于&#xff1a;最大为 M-1 个&#…

单例模式⭐️通过具体代码实现单例模式的不同实现以及周末总结

小伙伴们大家好&#xff0c;又是一个平平淡淡的周末&#xff0c;先来回顾下这周的情况吧 主线开发任务正常&#xff0c;没有滞后首次通过定时任务来处理脚本&#xff0c;测试通过熟悉定时任务的远程&#xff0c;本地来回切换 2023.12.16 天气阴 气温零下 一觉睡…