设为首页 收藏本站
查看: 982|回复: 0

[经验分享] PHP调用SQL Server存储过程

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2015-8-28 05:35:31 | 显示全部楼层 |阅读模式
  一、安装SQL Server Driver for PHP   
    在微软官网上发现了这个东西,他提供了一套PHP对MS2005/2008操作的全新函数库,并且支持UTF8,作为PHP的扩展运行。看来MS对PHP 还比较亲善,PHP自带的mssql操作函数对MS2005/2008的一些新功能不支持,MS就自己提供了解决方法,赞一个!不过只支持PHP5.2 /5.3,MS说目前在PHP 5.2上测试过,低版本的是否支持就不清楚了。我的系统正好也用的是PHP5.2,其它版本也懒得去测了。   
下载地址:http://www.microsoft.com/downloads/details.aspx?familyid=CCDF728B-1EA0-48A8-A84A-5052214CAAD9&displaylang=en   
下载后是个.exe的压缩包,解开后有下列.dll文件:   
php_sqlsrv_52_nts_vc6.dll   
php_sqlsrv_52_ts_vc6.dll   
php_sqlsrv_53_nts_vc6.dll   
php_sqlsrv_53_nts_vc9.dll   
php_sqlsrv_53_ts_vc6.dll   
php_sqlsrv_53_ts_vc9.dll   
要根据自己的PHP环境选择一个合适的.dll,压缩包的说明文档给出了适用范围:
  Driver file   
PHP version   
Thread safe?   
Use with PHP .dll
  php_sqlsrv_53_nts_vc6.dll   
5.3   
no   
php5.dll
  php_sqlsrv_53_nts_vc9.dll   
5.3   
no   
php5.dll
  php_sqlsrv_53_ts_vc6.dll   
5.3   
yes   
php5ts.dll
  php_sqlsrv_53_ts_vc9.dll   
5.3   
yes   
php5ts.dll
  php_sqlsrv_52_nts_vc6.dll   
5.2   
no   
php5.dll
  php_sqlsrv_52_ts_vc6.dll   
5.2   
yes   
php5ts.dll
  DLL名字称中的_vc6/_vc9表示你使用的PHP为vc6或vc9编译,PHP version中确定适用版本,Thread safe为该版本安全性,Use with PHP .dll是你PHP的安装方式。更多说明请参考文档。   
    我这里选择的是php_sqlsrv_52_ts_vc6.dll,拷贝到php/ext/下,然后在php.ini中添加一行 “extension=php_sqlsrv_52_ts_vc6.dll”,重启WEB服务。phpinfo();查看一下,如果有“sqlsrv”扩 展项,就表示安装成功了。   
二、安裝Microsoft SQL Server Native Client   
    这个是MSSQL的客户端存取程序,它提供了ODBC、OLE DB、ADO 等方式连接 MSSQL。 如果已经安装了MSSQL2005/2008,则已经安装了对应版本的此程序,不用单独安装了。   
    Microsoft SQL Server Native Client 2005支持SQL Server 7、2000、2005   
下载地址:http://www.microsoft.com/downloads/details.aspx?displaylang=zh-cn&FamilyID=50b97994-8453-4998-8226-fa42ec403d17,找到对应项后根据自己机器情况(X86/X64)选择下载。   
    Microsoft SQL Server Native Client 2008支持SQL Server 2000、2005、2008   
下载地址:http://www.microsoft.com/downloads/details.aspx?displaylang=zh-cn&FamilyID=c6c3e9ef-ba29-4a43-8d69-a2bed18fe73c,找到对应项后根据自己机器情况(X86/X64/IA64)选择下载。   
三、至此已经可以使用UTF8进行存取了   
    新建一个UTF8编码的文件,测试一下:
  $connstr = array("Database"=>"test","Uid"=>"sa","Pwd"=>"xxx","CharacterSet" => "UTF-8");   
$conn = sqlsrv_connect('127.0.0.1',$connstr);   
if($conn==false) print_r(sqlsrv_errors(),true);   
$sql = "SELECT TOP 10 * FROM table";   
if($data = sqlsrv_query($conn, $sql))   
{   
    while($row = sqlsrv_fetch_array($data,SQLSRV_FETCH_ASSOC))   
{   
        print_r($row);   
}   
}   
sqlsrv_close($conn);
  四、ADODB支持   
    看到上例可能要抓狂了,因为提供了全新的一套操作函数,使用起来不习惯,跟现有系统也不兼容。去下载了个最新版的ADODB后惊喜的发现它已经封装了该系列函数,帮我们解决了此问题。只需作个简单的修改:   
找到/adodb/drivers/adodb-mssqlnative.inc.php,在_connect方法后有一行:   
“ $connectionInfo = array("Database"=>$argDatabasename,'UID'=>$argUsername,'PWD'=>$argPassword);”   
改为:   
“ $connectionInfo = array("Database"=>$argDatabasename,'UID'=>$argUsername,'PWD'=>$argPassword,"CharacterSet" => 'UTF-8');”   
  ADODB下载:http://adodb.sourceforge.net   
OK了,测试代码:
  $conn = ADONewConnection('mssqlnative');   
$conn->Connect(DB_HOST,DB_USER,DB_PASS,DB_NAME);   
$ADODB_FETCH_MODE= ADODB_FETCH_ASSOC;   
$sql = "SELECT * FROM table";   
$data = $conn->GetAll($sql);   
print_r($data);
  五、
  <?php   
require 'dbconn.php';   
$userId = 1; // 定义输入参数     
$userName; // 定义返回值   
$stmt = mssql_init(&quot;P__Test_GetData&quot;, $conn) or die(&quot;initialize stored procedure failure&quot;);   
mssql_bind($stmt, &quot;@userid&quot;, $userId, SQLINT4);   
mssql_bind($stmt, &quot;@username&quot;, $userName, SQLVARCHAR, true);   
$rs = mssql_execute($stmt, false);   
echo &quot;This user name is: &quot;.$userName;   
?>

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-105146-1-1.html 上篇帖子: php非空验证 下篇帖子: PHP新的垃圾回收机制:Zend GC详解
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表