php7.4.3连接MSsql server方法

需要下载安装Microsoft Drivers for PHP for SQL Server驱动,

https://download.csdn.net/download/tjsoft/90568178

实操Win2008IISphp7.4.3连接SqlServer2008数据库所有安装包资源-CSDN文库

适用于 SQL Server 的 PHP 的 Microsoft 驱动程序支持与 SQL Server for PHP 应用程序的集成。驱动程序是 PHP 扩展,允许从 PHP 脚本中读取和写入 SQL Server 数据。这些驱动程序提供了用于访问 Azure SQL 数据库以及 SQL Server 2005 及更高版本的所有版本(包括 Express Edition)中的数据的接口。这些驱动程序利用 PHP 功能(包括 PHP 流)来读取和写入大型对象。

地址:https://msdn.microsoft.com/library/dn865013.aspx。下载后解压放到php对应的ext目录下。然后打开php.ini文件,在extension 后面添加一下配置

extension=php_pdo_sqlsrv_7_ts.dll

extension=php_sqlsrv_7_ts.dll

重启IIS,查看phpinfo(),确保apache已经支持sqlsrv。如下图所示:

<?php

echo phpinfo();

?>

并且安装sqlncli.msi,这个文件是协助windows环境访问sql server所在的数据库服务器的

三、通过odbc方式连接sqlserver系列。

需要在php.ini中开启php_pdo_odbc.dll扩展。

四、通过PDO方式连接sqlserver。

在php.ini中开启php_pdo_mssql.dll扩展。在phpinfo中可查看

五、通过COM方式连接。

下面是实现代码:

此示例从数据库中返回用户输入的字符串包含在名称中的产品的信息。从返回的产品列表中,用户可以看到评论,查看图片,上传图片,并对选定的产品撰写评论。

将以下代码放入名为adventureworks_demo.php的文件中:
超文本预处理器复制

复制代码
`<!--=============  
This file is part of a Microsoft SQL Server Shared Source Application.  
Copyright (C) Microsoft Corporation.  All rights reserved.  
  
THIS CODE `AND` INFORMATION ARE PROVIDED `"AS IS"` WITHOUT WARRANTY OF ANY  
KIND, EITHER EXPRESSED `OR` IMPLIED, INCLUDING BUT NOT LIMITED TO THE  
IMPLIED WARRANTIES OF MERCHANTABILITY `AND`/`OR` FITNESS `FOR` A  
PARTICULAR PURPOSE.  
============= *-->  
  
<!--Note: The presentation formatting of the example application -->  
<!-- is intentionally simple to emphasize the SQL Server -->  
<!-- data access code.-->  
<html>  
<head>  
<title>AdventureWorks Product Reviews</title>  
</head>  
<body>  
<h1 align=`'center'`>AdventureWorks Product Reviews</h1>  
<h5 align=`'center'`>This application is a demonstration of the   
                   procedural API (SQLSRV driver) of the Microsoft  
                   Drivers `for` PHP `for` SQL Server.</h5><br/>  
`<?php`  
$serverName = `"(local)\sqlexpress"`;  
$connectionOptions = `array`(`"Database"`=>`"AdventureWorks"`);  
  
`/* Connect using Windows Authentication. */`  
$conn = sqlsrv_connect( $serverName, $connectionOptions);  
`if`( $conn === `false` )  
`die`( FormatErrors( sqlsrv_errors() ) );  
  
`if`(`isset`($_REQUEST[`'action'`]))  
{  
`switch`( $_REQUEST[`'action'`] )  
{  
`/* Get AdventureWorks products by querying   
   against the product name.*/`  
`case` `'getproducts'`:  
$params = `array`(&$_POST[`'query'`]);  
$tsql = `"SELECT ProductID, Name, Color, Size, ListPrice   
FROM Production.Product   
WHERE Name LIKE '%' + ? + '%' AND ListPrice > 0.0"`;  
`/*Execute the query with a scrollable cursor so  
  we can determine the number of rows returned.*/`  
$cursorType = `array`(`"Scrollable"` => SQLSRV_CURSOR_KEYSET);  
$getProducts = sqlsrv_query($conn, $tsql, $params, $cursorType);  
`if` ( $getProducts === `false`)  
`die`( FormatErrors( sqlsrv_errors() ) );  
  
`if`(sqlsrv_has_rows($getProducts))  
{  
$rowCount = sqlsrv_num_rows($getProducts);  
BeginProductsTable($rowCount);  
`while`( $row = sqlsrv_fetch_array( $getProducts, SQLSRV_FETCH_ASSOC))  
{  
PopulateProductsTable( $row );  
}  
EndProductsTable();  
}  
`else`  
{  
DisplayNoProductsMsg();  
}  
GetSearchTerms( !`null` );  
  
`/* Free the statement and connection resources. */`  
sqlsrv_free_stmt( $getProducts );  
sqlsrv_close( $conn );  
`break`;  
  
`/* Get reviews for a specified productID. */`  
`case` `'getreview'`:  
GetPicture( $_GET[`'productid'`] );  
GetReviews( $conn, $_GET[`'productid'`] );  
sqlsrv_close( $conn );  
`break`;  
  
`/* Write a review for a specified productID. */`  
`case` `'writereview'`:  
DisplayWriteReviewForm( $_POST[`'productid'`] );  
`break`;  
  
`/* Submit a review to the database. */`  
`case` `'submitreview'`:  
`/*Prepend the review so it can be opened as a stream.*/`  
$comments = `"data://text/plain,"`.$_POST[`'comments'`];  
$stream = fopen( $comments, `"r"` );  
$tsql = `"INSERT INTO Production.ProductReview (ProductID,  
   ReviewerName,  
   ReviewDate,  
   EmailAddress,  
   Rating,  
   Comments)   
 VALUES (?,?,?,?,?,?)"`;  
$params = `array`(&$_POST[`'productid'`],  
&$_POST[`'name'`],  
date(`"Y-m-d"`),  
&$_POST[`'email'`],  
&$_POST[`'rating'`],   
&$stream);  
  
`/* Prepare and execute the statement. */`  
$insertReview = sqlsrv_prepare($conn, $tsql, $params);  
`if`( $insertReview === `false` )  
`die`( FormatErrors( sqlsrv_errors() ) );  
`/* By default, all stream data is sent at the time of  
query execution. */`  
`if`( sqlsrv_execute($insertReview) === `false` )  
`die`( FormatErrors( sqlsrv_errors() ) );   
sqlsrv_free_stmt( $insertReview );  
GetSearchTerms( `true` );  
  
`/* Display a list of reviews, including the latest addition. */`  
GetReviews( $conn, $_POST[`'productid'`] );  
sqlsrv_close( $conn );  
`break`;  
  
        `/* Display a picture of the selected product.*/`  
        `case` `'displaypicture'`:  
            $tsql = `"SELECT Name   
                     FROM Production.Product   
                     WHERE ProductID = ?"`;  
            $getName = sqlsrv_query($conn, $tsql,   
                                      `array`(&$_GET[`'productid'`]));  
            `if`( $getName === `false` )  
`die`( FormatErrors( sqlsrv_errors() ) );  
            `if` ( sqlsrv_fetch( $getName ) === `false` )  
`die`( FormatErrors( sqlsrv_errors() ) );  
            $name = sqlsrv_get_field( $getName, 0);  
            DisplayUploadPictureForm( $_GET[`'productid'`], $name );  
            sqlsrv_close( $conn );  
            `break`;  
  
        `/* Upload a new picture for the selected product. */`  
        `case` `'uploadpicture'`:  
            $tsql = `"INSERT INTO Production.ProductPhoto (LargePhoto)  
                     VALUES (?); SELECT SCOPE_IDENTITY() AS PhotoID"`;  
            $fileStream = fopen($_FILES[`'file'`][`'tmp_name'`], `"r"`);  
            $uploadPic = sqlsrv_prepare($conn, $tsql, `array`(  
                       `array`(&$fileStream,   
                             SQLSRV_PARAM_IN,   
                             SQLSRV_PHPTYPE_STREAM(SQLSRV_ENC_BINARY),  
                             SQLSRV_SQLTYPE_VARBINARY(`'max'`))));  
            `if`( $uploadPic === `false` )  
`die`( FormatErrors( sqlsrv_errors() ) );  
            `if`( sqlsrv_execute($uploadPic) === `false` )  
`die`( FormatErrors( sqlsrv_errors() ) );  
  
`/*Skip the open result set (row affected). */`  
$next_result = sqlsrv_next_result($uploadPic);  
`if`( $next_result === `false` )  
`die`( FormatErrors( sqlsrv_errors() ) );  
  
`/* Fetch the next result set. */`  
`if`( sqlsrv_fetch($uploadPic) === `false`)  
`die`( FormatErrors( sqlsrv_errors() ) );  
  
`/* Get the first field - the identity from INSERT. */`  
$photoID = sqlsrv_get_field($uploadPic, 0);  
  
`/* Associate the new photoID with the productID. */`  
$tsql = `"UPDATE Production.ProductProductPhoto  
 SET ProductPhotoID = ?  
 WHERE ProductID = ?"`;  
  
$reslt = sqlsrv_query($conn, $tsql, `array`(&$photoID, &$_POST[`'productid'`]));  
`if`($reslt === `false` )  
`die`( FormatErrors( sqlsrv_errors() ) );  
  
GetPicture( $_POST[`'productid'`]);  
DisplayWriteReviewButton( $_POST[`'productid'`] );  
GetSearchTerms (!`null`);  
sqlsrv_close( $conn );  
`break`;  
}`//End Switch  `
}  
`else`  
{  
    GetSearchTerms( !`null` );  
}  
  
`function` `GetPicture`( $productID )  
{  
    `echo` `"<table align='center'><tr align='center'><td>"`;  
    `echo` `"<img src='photo.php?productId="`.$productID.`"'   
      height='150' width='150'/></td></tr>"`;  
    `echo` `"<tr align='center'><td><a href='?action=displaypicture&  
          productid="`.$productID.`"'>Upload new picture.</a></td></tr>"`;  
    `echo` `"</td></tr></table></br>"`;  
}  
  
`function` `GetReviews`( $conn, $productID )  
{  
    $tsql = `"SELECT ReviewerName,   
             CONVERT(varchar(32), ReviewDate, 107) AS [ReviewDate],  
 Rating,   
 Comments   
             FROM Production.ProductReview   
             WHERE ProductID = ?   
             ORDER BY ReviewDate DESC"`;  
`/*Execute the query with a scrollable cursor so  
  we can determine the number of rows returned.*/`  
$cursorType = `array`(`"Scrollable"` => SQLSRV_CURSOR_KEYSET);  
$getReviews = sqlsrv_query( $conn, $tsql, `array`(&$productID), $cursorType);  
`if`( $getReviews === `false` )  
`die`( FormatErrors( sqlsrv_errors() ) );  
`if`(sqlsrv_has_rows($getReviews))  
{  
$rowCount = sqlsrv_num_rows($getReviews);  
`echo` `"<table width='50%' align='center' border='1px'>"`;  
`echo` `"<tr bgcolor='silver'><td>$rowCount Reviews</td></tr></table>"`;  
`while` ( sqlsrv_fetch( $getReviews ) )  
{  
$name = sqlsrv_get_field( $getReviews, 0 );  
$date = sqlsrv_get_field( $getReviews, 1 );  
$rating = sqlsrv_get_field( $getReviews, 2 );  
`/* Open comments as a stream. */`  
$comments = sqlsrv_get_field( $getReviews, 3,   
SQLSRV_PHPTYPE_STREAM(SQLSRV_ENC_CHAR));  
DisplayReview($productID,  
  $name,  
              $date,  
              $rating,  
              $comments );  
}  
}  
    `else`  
    {   
DisplayNoReviewsMsg();  
}  
    DisplayWriteReviewButton( $productID );  
    sqlsrv_free_stmt( $getReviews );  
}  
  
`/*** Presentation and Utility Functions ***/`  
  
`function` `BeginProductsTable`($rowCount)  
{  
    `/* Display the beginning of the search results table. */`  
$headings = `array`(`"Product ID"`, `"Product Name"`,  
`"Color"`, `"Size"`, `"Price"`);  
    `echo` `"<table align='center' cellpadding='5'>"`;   
    `echo` `"<tr bgcolor='silver'>$rowCount Results</tr><tr>"`;  
    `foreach` ( $headings `as` $heading )  
    {  
        `echo` `"<td>$heading</td>"`;  
    }  
    `echo` `"</tr>"`;  
}  
  
`function` `DisplayNoProductsMsg`()  
{  
    `echo` `"<h4 align='center'>No products found.</h4>"`;  
}  
  
`function` `DisplayNoReviewsMsg`()  
{  
    `echo` `"<h4 align='center'>There are no reviews for this product.</h4>"`;  
}  
  
`function` `DisplayReview`( $productID, $name, $date, $rating, $comments)  
{  
    `/* Display a product review. */`  
    `echo` `"<table style='WORD-BREAK:BREAK-ALL' width='50%'   
                 align='center' border='1' cellpadding='5'>"`;   
    `echo` `"<tr>  
            <td>ProductID</td>  
            <td>Reviewer</td>  
            <td>Date</td>  
            <td>Rating</td>  
          </tr>"`;  
      `echo` `"<tr>  
              <td>$productID</td>  
              <td>$name</td>  
              <td>$date</td>  
              <td>$rating</td>  
            </tr>  
            <tr>  
              <td width='50%' colspan='4'>"`;  
                 fpassthru( $comments );  
     `echo` `"</td></tr></table><br/><br/>"`;  
}  
  
`function` `DisplayUploadPictureForm`( $productID, $name )  
{  
    `echo` `"<h3 align='center'>Upload Picture</h3>"`;  
    `echo` `"<h4 align='center'>$name</h4>"`;  
    `echo` `"<form align='center' action='adventureworks_demo.php'  
                    enctype='multipart/form-data' method='POST'>  
<input type='hidden' name='action' value='uploadpicture'/>  
<input type='hidden' name='productid' value='$productID'/>  
<table align='center'>  
         <tr>  
           <td align='center'>  
             <input id='fileName' type='file' name='file'/>  
           </td>  
         </tr>  
         <tr>  
           <td align='center'>  
            <input type='submit' name='submit' value='Upload Picture'/>  
           </td>  
         </tr>  
</table>  
</form>"`;  
}  
  
`function` `DisplayWriteReviewButton`( $productID )  
{  
    `echo` `"<table align='center'><form action='adventureworks_demo.php'   
                 enctype='multipart/form-data' method='POST'>  
          <input type='hidden' name='action' value='writereview'/>  
          <input type='hidden' name='productid' value='$productID'/>  
          <input type='submit' name='submit' value='Write a Review'/>  
          </p></td></tr></form></table>"`;  
}  
  
`function` `DisplayWriteReviewForm`( $productID )  
{  
    `/* Display the form for entering a product review. */`  
    `echo` `"<h5 align='center'>Name, E-mail, and Rating are required fields.</h5>"`;  
    `echo` `"<table align='center'>  
<form action='adventureworks_demo.php'   
                enctype='multipart/form-data' method='POST'>  
<input type='hidden' name='action' value='submitreview'/>  
<input type='hidden' name='productid' value='$productID'/>  
<tr>  
<td colspan='5'>Name: <input type='text' name='name' size='50'/></td>  
</tr>  
<tr>  
<td colspan='5'>E-mail: <input type='text' name='email' size='50'/></td>  
</tr>  
<tr>  
<td>Rating: 1<input type='radio' name='rating' value='1'/></td>  
<td>2<input type='radio' name='rating' value='2'/></td>  
<td>3<input type='radio' name='rating' value='3'/></td>  
<td>4<input type='radio' name='rating' value='4'/></td>  
<td>5<input type='radio' name='rating' value='5'/></td>  
</tr>  
<tr>  
<td colspan='5'>  
<textarea rows='20' cols ='50' name='comments'>[Write comments here.]</textarea>  
</td>  
</tr>  
<tr>  
<td colspan='5'>  
                 <p align='center'><input type='submit' name='submit' value='Submit Review'/>  
</td>  
</tr>  
</form>  
          </table>"`;  
}  
  
`function` `EndProductsTable`()  
{   
    `echo` `"</table><br/>"`;   
}  
  
`function` `GetSearchTerms`( $success )  
{  
    `/* Get and submit terms for searching the database. */`  
    `if` (is_null( $success ))  
    {  
`echo` `"<h4 align='center'>Review successfully submitted.</h4>"`;}  
`echo` `"<h4 align='center'>Enter search terms to find products.</h4>"`;  
`echo` `"<table align='center'>  
            <form action='adventureworks_demo.php'   
                  enctype='multipart/form-data' method='POST'>  
            <input type='hidden' name='action' value='getproducts'/>  
            <tr>  
               <td><input type='text' name='query' size='40'/></td>  
            </tr>  
            <tr align='center'>  
               <td><input type='submit' name='submit' value='Search'/></td>  
            </tr>  
            </form>  
            </table>"`;  
}  
  
`function` `PopulateProductsTable`( $values )  
{  
    `/* Populate Products table with search results. */`  
    $productID = $values[`'ProductID'`];  
    `echo` `"<tr>"`;  
    `foreach` ( $values `as` $key => $value )  
    {  
        `if` ( 0 == strcasecmp( `"Name"`, $key ) )  
        {  
            `echo` `"<td><a href='?action=getreview&productid=$productID'>$value</a></td>"`;  
        }  
        `elseif`( !is_null( $value ) )  
        {  
            `if` ( 0 == strcasecmp( `"ListPrice"`, $key ) )  
            {  
                `/* Format with two digits of precision. */`  
                $formattedPrice = sprintf(`"%.2f"`, $value);  
                `echo` `"<td>$$formattedPrice</td>"`;  
            }  
            `else`  
            {  
                `echo` `"<td>$value</td>"`;  
            }  
        }  
        `else`  
        {  
            `echo` `"<td>N/A</td>"`;  
        }  
    }  
    `echo` `"<td>  
            <form action='adventureworks_demo.php'   
                  enctype='multipart/form-data' method='POST'>  
            <input type='hidden' name='action' value='writereview'/>  
            <input type='hidden' name='productid' value='$productID'/>  
            <input type='submit' name='submit' value='Write a Review'/>  
            </td></tr>  
            </form></td></tr>"`;  
}  
  
`function` `FormatErrors`( $errors )  
{  
    `/* Display errors. */`  
    `echo` `"Error information: <br/>"`;  
  
    `foreach` ( $errors `as` $error )  
    {  
        `echo` `"SQLSTATE: "`.$error[`'SQLSTATE'`].`"<br/>"`;  
        `echo` `"Code: "`.$error[`'code'`].`"<br/>"`;  
        `echo` `"Message: "`.$error[`'message'`].`"<br/>"`;  
    }  
}  
`?>`  
</body>  
</html>  
`

LOB 示例

photo.php 脚本返回指定 ProductID 的产品照片。这个脚本被调用自 adventureworks_demo.php 脚本。

将以下代码放入名为 photo.php 的文件中:
超文本预处理器复制

复制代码
<?php`  
`/*=============  
This file is part of a Microsoft SQL Server Shared Source Application.  
Copyright (C) Microsoft Corporation.  All rights reserved.  
  
THIS CODE AND INFORMATION ARE PROVIDED "AS IS" WITHOUT WARRANTY OF ANY  
KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE  
IMPLIED WARRANTIES OF MERCHANTABILITY AND/OR FITNESS FOR A  
PARTICULAR PURPOSE.  
============= */`  
  
$serverName = `"(local)\sqlexpress"`;  
$connectionInfo = `array`( `"Database"`=>`"AdventureWorks"`);  
  
`/* Connect using Windows Authentication. */`  
$conn = sqlsrv_connect( $serverName, $connectionInfo);  
`if`( $conn === `false` )  
{  
     `echo` `"Could not connect.\n"`;  
     `die`( print_r( sqlsrv_errors(), `true`));  
}  
  
`/* Get the product picture for a given product ID. */`  
$tsql = `"SELECT LargePhoto   
         FROM Production.ProductPhoto AS p  
         JOIN Production.ProductProductPhoto AS q  
         ON p.ProductPhotoID = q.ProductPhotoID  
         WHERE ProductID = ?"`;  
  
$params = `array`(&$_REQUEST[`'productId'`]);  
  
`/* Execute the query. */`  
$stmt = sqlsrv_query($conn, $tsql, $params);  
`if`( $stmt === `false` )  
{  
     `echo` `"Error in statement execution.</br>"`;  
     `die`( print_r( sqlsrv_errors(), `true`));  
}  
  
`/* Retrieve the image as a binary stream. */`  
$getAsType = SQLSRV_PHPTYPE_STREAM(SQLSRV_ENC_BINARY);  
`if` ( sqlsrv_fetch( $stmt ) )  
{  
   $image = sqlsrv_get_field( $stmt, 0, $getAsType);  
   fpassthru($image);  
}  
`else`  
{  
     `echo` `"Error in retrieving data.</br>"`;  
     `die`(print_r( sqlsrv_errors(), `true`));  
}  
  
`/* Free the statement and connection resources. */`  
sqlsrv_free_stmt( $stmt );  
sqlsrv_close( $conn );  
`?>`  
`

另请参阅

Microsoft Drivers for PHP for SQL Server - PHP drivers for SQL Server | Microsoft Learn

相关推荐
奔跑吧 android18 分钟前
【android bluetooth 协议分析 07】【SDP详解 2】【SDP 初始化】
android·bluetooth·aosp15·bt·gd·sdp_init
梦否3 小时前
Android 代码热度统计(概述)
android
xchenhao6 小时前
基于 Flutter 的开源文本 TTS 朗读器(支持 Windows/macOS/Android)
android·windows·flutter·macos·openai·tts·朗读器
coder_pig7 小时前
跟🤡杰哥一起学Flutter (三十五、玩转Flutter滑动机制📱)
android·flutter·harmonyos
消失的旧时光-19438 小时前
OkHttp SSE 完整总结(最终版)
android·okhttp·okhttp sse
ansondroider9 小时前
OpenCV 4.10.0 移植 - Android
android·人工智能·opencv
hsx66611 小时前
Kotlin return@label到底怎么用
android
itgather12 小时前
安卓设备信息查看器 - 源码编译
android
whysqwhw12 小时前
OkHttp之buildSrc模块分析
android
hsx66612 小时前
从源码角度理解Android事件的传递流程
android