侯体宗的博客
  • 首页
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

PHP连接MSSQL方法汇总

php  /  管理员 发布于 7年前   228

 为了能让PHP连接MSSQL,系统需要安装MSSQL,PHP,且在PHP.ini中的配置中,将 ;extension=php_mssql.dll前面的;去掉

1.连接MSSQL

  $conn=mssql_connect("实例名或者服务器IP","用户名","密码");  //测试连接  if($conn)  {  echo "连接成功";  }

2.选择要连接的数据库      

 mssql_select_db("dbname");

3.执行查询

$rs = mssql_query("select top 1 id,username from tbname",$conn);// 或者直接执行update,insert等语句,可以不用为返回结果赋值mssql_query("update tbname set username='niunv' where id=1");

 4.获取记录集行数      

 echo mssql_num_rows($rs);

5.获取记录集     

 if($row=mssql_fetch_array($rs))  {  $id = $row[0];//获取ID字段值  $username = $row[1];//获取username字段值  }

6.获取新增记录的ID
       将id字段设置为IDENTITY字段,执行insert语句以后,就会产生一个 @@IDENTITY 全局变量值,查询出来就是最后一条新增记录的ID了.

  mssql_query("insert into tbname(username) values ('nv')",$conn);   $rs = mssql_query("select @@IDENTITY as id",$conn);  if($row=mssql_fetch_array($rs))  {  echo $row[0];  }

7.释放记录集    

 mssql_free_result($rs);

 8.关闭连接    

 mssql_close($conn);  

       注:用PHP操作MSSQL比在ASP连接MYSQL要简单,所以,当需要MSSQL与MYSQL并存时,用PHP连接MSSQL来操作MYSQL与MSSQL并存比较简单好用.如果是ASP连接MYSQL,需要安装一个MYSQL驱动,默认windows的ODBC没有安装,很遗憾...   

  •   在web服务器上至少安装了mssql的客户端    
  •   打开php.ini把;extension=php_mssql.dll   前面的分号去掉  
  •       有必要话:需要制定extension_dir  
  •   推荐使用   php<=4.0.9     <=5.0.3目前   我还没有连接成功过4.010和   5.0.3  
  •   数据库的 连接分页可以到phpe.net上获取到相应的class   

  下面是我修改的 一个class   

 server = $Server;  $this->userName = $UserName;  $this->passWord = $PassWord;  $this->dataBase = $DataBase;  }  /**  *数据库连接  **/  function db_connect(){  $this->linkID = mssql_pconnect($this->server,$this->userName,$this->passWord);  if(!$this->linkID){  $this->ER = "db_connect($this->server,$this->userName,$this->passWord) error";  return 0;  }  if (!mssql_select_db($this->dataBase,$this->linkID)) {  $this->ER = "mssql_select_db($this->dataBase,$this->lastInsertID) error";  return 0;  }  return $this->linkID;  }   /**public  *  function: Check the database, if exist then select  *  exist: return 1  *  not exist: return 0  */  function selectDatabase(){  if(mssql_select_db($this->dataBase))  return 1;  else  return 0;  }   /**  *数据操作  **/  function  query($Str){  if ($this->linkID == 0) {  $this->ER = "数据库还没有连接!!";  }      $this->queryResult = mssql_query($Str);   //$this->queryResult = mssql_query($Str,$this->linkID);  if (!$this->queryResult) {     $this->ER = "$Str.没有操作成功,query error!!";  return 0;//****************对于php 4.3.9以上版本的错误用1  }  return $this->queryResult;  }   /**  *数据获取  **/  function fetch_array($result){  if($result != "") $this->queryResult = $result;  $rec =mssql_fetch_array($this->queryResult);   if(is_array($rec)){  return $rec;   }   //$this->ER = "没有获取数据!";  return 0;  }   /**public  *  function: Free the Query Result  *  success return 1  *  failed: return 0  */  function freeResult($result=""){  if($result != "") $this->queryResult = $result;  return mssql_free_result($this->queryResult);  }     /**  *获取影响的的行数  *获取操作过的行数  **/  function num_rows($result=""){  if ($result != "") {  $this->queryResult = $result;  $row = mssql_num_rows($this->queryResult);  return $row;  }  }     /**  *获取查询结果---多个  **/  function result_ar($str=''){  if (empty($str)) {  return 0;  }  $back = array();  $this->queryResult = $this->query($str);   while ($row = $this->fetch_array($this->queryResult)) {  $back[] = $row;  }  return $back;  }   /**  *数据库信息分页  *$Result 数据库操作  *str ==sql语句   *page ==第几页  *showNum ==显示几页  */  function page($Str,$Page=0,$ShowNum=5){  $back = array();//返回数据  $maxNum = 0;  if ($Str == "") {  $this->ER = "没有数据";  return  0;  }  $this->queryResult = $this->query($Str);  if($this->queryResult){  if($Page==""){  $nopa=0;  }else{  $nopa = ($Page-1)*$ShowNum;  if ($nopa<0) {  $nopa = 0;  }  }  $maxNum=$this->num_rows($this->queryResult);  $k=0;  $i=0;  $dd=$this->fetch_array($this->queryResult);   while($dd&&$nopa<=$maxNum&&$i<$ShowNum){  if($nopa >= $maxNum)  $nopa = $maxNum;  mssql_data_seek($this->queryResult,$nopa);   $row=$this->fetch_array($this->queryResult);   $nopa++;  $i++;  $back[] = $row;   if ($nopa >=$maxNum) {  break;  }  }  }  $this->pageNum = $maxNum;  return $back;  }   /**  *分页的html页码  */  function  page_html($DataNum=0,$Page=1,$ShowNum=3,$web,$Post=''){  if ($DataNum == 0) {  $back =  "没有要查询的数据";  }else {  if ($ShowNum<=0) {  $ShowNum = 3;  }  if ($Page<=0) {  $Page = 1;  }  if (empty($web)) {  $web = "#";  }  $pageNum = ceil($DataNum/$ShowNum);  if ($Page <= 1) {  $top =  "首页<<";  }else {  $top = "首页<< ";  }  if ($Page !==1) {  $upPage =  "上一页";  }else {  $upPage = "上一页";  }  if ($Page < $pageNum) {  $downPage = "下一页";  }else {  $downPage = "下一页";  }  if ($Page == $pageNum) {  $foot = ">>尾页";  }else {  $foot = " >>尾页";  }   $back = <<

以上就是PHP连接MSSQL方法的总结,希望对大家的学习有所帮助。

您可能感兴趣的文章:

  • PHP连接MSSQL时nvarchar字段长度被截断为255的解决方法
  • PHP连接MSSQL2008/2005数据库(SQLSRV)配置实例
  • php连接mssql数据库的几种方法
  • php连接mssql的一些相关经验及注意事项
  • 关于php连接mssql:pdo odbc sql server
  • php连接MSsql server的五种方法总结


  • 上一条:
    PHP共享内存用法实例分析
    下一条:
    PHP 开发者该知道的 5 个 Composer 小技巧
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • Laravel从Accel获得5700万美元A轮融资(0个评论)
    • PHP 8.4 Alpha 1现已发布!(0个评论)
    • 用Time Warden监控PHP中的代码处理时间(0个评论)
    • 在PHP中使用array_pop + yield实现读取超大型目录功能示例(0个评论)
    • Property Hooks RFC在PHP 8.4中越来越接近现实(0个评论)
    • 近期文章
    • 在windows10中升级go版本至1.24后LiteIDE的Ctrl+左击无法跳转问题解决方案(0个评论)
    • 智能合约Solidity学习CryptoZombie第四课:僵尸作战系统(0个评论)
    • 智能合约Solidity学习CryptoZombie第三课:组建僵尸军队(高级Solidity理论)(0个评论)
    • 智能合约Solidity学习CryptoZombie第二课:让你的僵尸猎食(0个评论)
    • 智能合约Solidity学习CryptoZombie第一课:生成一只你的僵尸(0个评论)
    • 在go中实现一个常用的先进先出的缓存淘汰算法示例代码(0个评论)
    • 在go+gin中使用"github.com/skip2/go-qrcode"实现url转二维码功能(0个评论)
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(95个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2016-10
    • 2016-11
    • 2017-06
    • 2017-07
    • 2017-08
    • 2017-09
    • 2017-11
    • 2017-12
    • 2018-01
    • 2018-02
    • 2018-03
    • 2020-03
    • 2020-04
    • 2020-05
    • 2020-06
    • 2020-07
    • 2020-09
    • 2021-02
    • 2021-03
    • 2021-04
    • 2021-05
    • 2021-06
    • 2021-07
    • 2021-08
    • 2021-09
    • 2021-10
    • 2021-11
    • 2021-12
    • 2022-01
    • 2022-02
    • 2022-05
    • 2022-06
    • 2022-07
    • 2022-08
    • 2022-09
    • 2022-10
    • 2022-11
    • 2022-12
    • 2023-01
    • 2023-02
    • 2023-03
    • 2023-04
    • 2023-05
    • 2023-06
    • 2023-07
    • 2023-08
    • 2023-09
    • 2023-10
    • 2023-11
    • 2023-12
    • 2024-01
    • 2024-02
    • 2024-03
    • 2024-04
    • 2024-05
    • 2024-06
    • 2024-07
    • 2024-09
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客