收藏 分销(赏)

php连接mssql两种方法.docx

上传人:二*** 文档编号:4767779 上传时间:2024-10-12 格式:DOCX 页数:79 大小:2.15MB
下载 相关 举报
php连接mssql两种方法.docx_第1页
第1页 / 共79页
本文档共79页,全文阅读请下载到手机保存,查看更方便
资源描述
php连接mssql两种方法(com &amp; pdo) 分类: MSSQL类 php 2009-11-13 11:31 1309人阅读 评论(0) 收藏 举报 phpextension服务器数据库扩展query 一、 使用COM 1、首先是准备工作: 在Windows下通过PHP访问MSSQL SERVER 2000,可以有两种方式, (1)利用COM (2)一种是使用MSSQL_系列函数  要使用这两种都需要在php.ini进行设定: (1)允许 DCOM,需要将php.ini中的 ;com.allow_dcom=TRUE前的分号";"去掉。 (2)使用MSSQL扩展,需要php.ini中的 ;extension=php_mssql.dll前的分号";"去掉。 (3)确认extension_dir为正确路径,以本机为例:extension_dir = "c:/AppServ/php5/ext"。  (4)如果仍然机器报错说找不到c:/AppServ/php5/ext/php_mssql.dll但明明存在这个文件。        解决方法:将php_mssql.dll,ntwdblib.dll拷贝到系统目录/system32下重启测试。。        (注:上面两个dll文件不在相同目录下,我的为c:/AppServ/php5/ext/php_mssql.dll;c:/AppServ/php5/ntwdblib.dll) 另外设置好了后记得重启服务器哦。 我的PHP环境是用AppServ搭建的,我这样做了后,访问MSSQL SERVER一切正常。若你仍然有问题,请查阅PHP手册php.ini的设置。 2、利用COM访问MSSQL SERVER的简单方法    $conn = new COM("ADODB.Connection") or die("Cannot start ADO");    //首先声明一个连接对象    $connstr = "Provider=SQLOLEDB;                Persist Security Info=False;                User ID=youruid;                Password=yourpwd;                Initial Catalog=yourdatabase;                Data Source=127.0.0.1";    //设置连接字符串(很奇怪Data Soure为localhost或服务器名不行总是报错而为(local)或127.0.0.1却行,希望哪个高手帮我说明一下)    $conn->Open($connstr); //建立数据库连接    $sqlstr = "select * from test"; //设置查询字符串    $rs = $conn->Execute($sqlstr); //执行查询获得结果    或者       //$rs = new com("adodb.recordset");       //声明一个数据集对象       //$rs->open($sqlstr,$conn);//,3,3);          //获得数据集rcordset内容    $num_cols = $rs->Fields->Count();   //得到数据集列数     while (!$rs->EOF)       //输出结果    {       echo $rs->Fields['name']->Value."<BR>"; // 'name'为字段名,需要明确制定       $rs->MoveNext();       或者       //for ($i=0; $i < $num_columns; $i++)       //{                //echo $fld[$i]->value . "/t";       //}       //echo "/n";                //$rs->MoveNext();    }    $rs->Close();       $conn->Close();    $rs = null;    $conn = null; 3、使用MSSQL_函数访问MSSQL SERVER的简单方法    $hostname = "yourhoustname";    $username = "yourusername";    $password = "yourpassword";     $conn = mssql_connect($hostname,$username,$password) or die("DATABASE FAILED TO RESPOND.");    //建立连接    $dbName = "yourdatabase";    $ret=mssql_select_db($dbName); //选择数据库     $sqlstr = "select * from test"; //设置查询字符串    $result=mssql_query($query); //执行查询获得结果      while($line = mssql_fetch_row($result))   //输出结果    {       echo "$line[0],$line[1]";       //mssql_fetch_row每次返回一个enumerated(列举) array,直到没有数据而返回false    }    或者        //while($row = mssql_fetch_array($result))        //{        //echo $row["name"];        或者        //echo $row[0],$row[1];        //mssql_fetch_array每次返回一个数字索引数组或一个相关数组,直到没有数据而返回false        //} 题外:    关于通过PHP访问MSSQL SERVER的小结就是这些了。希望能对你有所帮助,第一次写又是初学,请你指出,共同进步。 求助:    1、我在设置连接字符串的时候,为什么Data Soure为localhost或服务器名不行总是报错而为(local)或127.0.0.1却行,希望哪个高手帮我说明一下    2、我在设置查询字符串的时候,如何对"LIKE '%-'"(单引号内为一个百分号和一个短横线)进行转义   二、 使用pdo 1、首先仍然是准备工作:    (1)使用PDO扩展,需要将php.ini中的 ;extension=php_pdo.dll前的分号";"去掉。    (2)访问MSSQL,需要将php.ini中的 ;extension=php_pdo_mssql.dll前的";"去掉(没有则添加)。          补充:如果你需要访问MySQL,需要将php.ini中的 ;extension=php_pdo_mssql.dll前的";"去掉。                    其他数据库请去掉相应扩展前的";"。    (3)确认extension_dir为正确路径,以本机为例:extension_dir = "c:/AppServ/php5/ext"。     (4)如果仍然机器报错说找不到c:/AppServ/php5/ext/php_mssql.dll但明明存在这个文件。        解决方法:将php_mssql.dll,ntwdblib.dll拷贝到系统目录/system32下重启测试。。        (注:上面两个dll文件不在相同目录下,我的为c:/AppServ/php5/ext/php_mssql.dll;c:/AppServ/php5/ntwdblib.dll)        另外:设置完毕后仍然记得要重启服务器哦 2、使用PDO访问MSSQL SERVER的简单方法 $username = yourusername; $pwd = yourpassword; try {     //??host=127.0.0.1可用;(local)不可用;localhost不可用;MAXY不可用    $dbh = new PDO('mssql:host=127.0.0.1;dbname=yourdatabase',$username,$pwd);    //声明一个PDO对象并指定它的连接字符串    $sqlstri = "select * from UpLow";    //指定查询字符串    foreach ($dbh->query($sqlstri) as $row)    //执行查询获得结果,并输出    { print_r($row); 或者 //echo $row['name'];    //指定字段输出    } } catch (PDOException $e) {    print "Error!;".$e->getMessage()."<br>"; }   mysqlexception数据库extensionquery  PDO(PHP Data Object) 是PHP 5新出来的东西,在PHP 6都要出来的时候,PHP 6只默认使用PDO来处理数据库,将把所有的数据库扩展移到了PECL,那么默认就是没有了我们喜爱的php_mysql.dll之类的了,那怎么办捏,我们只有与时俱进了,我就小试了一把PDO。(本文只是入门级的,高手可以略过,呵呵)   【PDO是啥】   PDO是PHP 5新加入的一个重大功能,因为在PHP 5以前的php4/php3都是一堆的数据库扩展来跟各个数据库的连接和处理,什么 php_mysql.dll、php_pgsql.dll、php_mssql.dll、php_sqlite.dll等等扩展来连接MySQL、PostgreSQL、MS SQL Server、SQLite,同样的,我们必须借助 ADOdb、PEAR::DB、PHPlib::DB之类的数据库抽象类来帮助我们,无比烦琐和低效,毕竟,php代码的效率怎么能够我们直接用C/C++写的扩展斜率高捏?所以嘛,PDO的出现是必然的,大家要平静学习的心态去接受使用,也许你会发现能够减少你不少功夫哦。   【安装PDO】   我是在Windows XP SP2 上面,所以嘛,整个过程都是在Windows行进行的啦,至于Linux/FreeBSD 等平台,请自行查找资料设置安装。 我的是PHP 5.1.4,已经自带有了php_pdo.dll的扩展,不过需要稍微设置一下才能使用。   打开 c:/windows/php.ini ,那是我的PHP配置文件,找到下面这行:   extension_dir   这个就是我们扩展存在的目录,我的PHP 5扩展是在:C:/php5/ext,那么我就把这行改成:   extension_dir = "C:/php5/ext"   然后再往php.ini下面找到:   ;;;;;;;;;;;;;;;;;;;;;;   ; Dynamic Extensions ;   ;;;;;;;;;;;;;;;;;;;;;;   下面有一堆类似 ;extension=php_mbstring.dll 的东西,这里就是PHP扩展加载的配置了,我们再最后面添加上我们PDO的扩展: extension=php_pdo.dll extension=php_pdo_mysql.dll extension=php_pdo_pgsql.dll extension=php_pdo_sqlite.dll extension=php_pdo_mssql.dll extension=php_pdo_odbc.dll extension=php_pdo_firebird.dll ;extension=php_pdo_oci8.dll   各种PDO的驱动,能给加上的全给加上,不过后面的php_pdo_oci8.dll,因为我没有安装Oralce数据库,所以没有这个,就使用分号注释掉它。然后重启我们的Web服务器, IIS/Apache,我的是IIS,嘿嘿,表鄙视我,在Windows上,简单嘛。   重启后,在我们Web服务器的文档目录下写一个phpinfo.php的文件,加上这些: <?  phpinfo(); ?>   然后打开我们可爱的浏览器:IE/FireFox,我的是FireFox 2.0,刚下载的,很爽,不怕流氓软件,哈哈。   在浏览器里面输入:http://localhost/phpinfo.php,如果你的这个页面路径不一致,请自行输入。   输出的内容中,如果你能够顺利的看到: PDO PDO support enabled PDO drivers mysql, pgsql, sqlite, mssql, odbc, firebird     后面有各种驱动的说明:PDO_Firebird,pdo_mssql,pdo_mysql,PDO_ODBC,pdo_pgsql,pdo_sqlite   那么,恭喜你安装成功了,否则请仔细检查上面的步骤。   【牛刀小小试】   我用的是MySQL 4.0.26,但是我个人推荐大家使用 MySQL 4.1.x 或者 MySQL 5.0.x,因为那些版本有很多有趣的东西值得去学习。我们这里PDO需要连接的就是我的MySQL 4.0啦,如果你没有安装MySQL,请自行安装。我们建立好了MySQL,并且在test库里添加了表foo,包括 id,name,gender,time等四个字段。   我们开始构造第一个PDO应用,建立一个pdo.php文件在Web文档目录下: <?php  $dsn = "mysql:host=localhost;dbname=test";  $db = new PDO($dsn, 'root', '');  $count = $db->exec("INSERT INTO foo SET name = 'heiyeluren',gender='男',time=NOW()");  echo $count;  $db = null; ?>   不明白啥意思,俺们来慢慢讲讲。这行: $dsn = "mysql:host=localhost;dbname=test";   就是构造我们的DSN(数据源),看看里面的信息包括:数据库类型是mysql,主机地址是localhost,数据库名称是test,就这么几个信息。不同数据库的数据源构造方式是不一样的。 $db = new PDO($dsn, 'root', '');   初始化一个PDO对象,构造函数的参数第一个就是我们的数据源,第二个是连接数据库服务器的用户,第三个参数是密码。我们不能保证连接成功,后面我们会讲到异常情况,这里我们姑且认为它是连接成功的。 $count = $db->exec("INSERT INTO foo SET name = 'heiyeluren',gender='男',time=NOW()"); echo $count;   调用我们连接成功的PDO对象来执行一个查询,这个查询是一个插入一条记录的操作,使用PDO::exec() 方法会返回一个影响记录的结果,所以我们输出这个结果。最后还是需要结束对象资源: $db = null;   默认这个不是长连接,如果需要数据库长连接,需要最后加一个参数:array(PDO::ATTR_PERSISTENT => true) 变成这样: $db = new PDO($dsn, 'root', '', array(PDO::ATTR_PERSISTENT => true));   一次操作就这么简单,也许跟以前的没有太大区别,跟ADOdb倒是有几分相似。  【继续了解】   如果我们想提取数据的话,那么就应该使用数据获取功能。(下面用到的$db都是上面已经连接好的对象) <?php  foreach($db->query("SELECT * FROM foo")){   print_r($row);  } ?>   我们也可以使用这种获取方式: <?php  $rs = $db->query("SELECT * FROM foo");  while($row = $rs->fetch()){   print_r($row);  } ?>   如果想一次把数据都获取到数组里可以这样: <?php $rs = $db->query("SELECT * FROM foo"); $result_arr = $rs->fetchAll(); print_r($result_arr); ?> Array ([0] => Array(  [id] => 1  [0] => 1  [name] => heiyeluren  [1] => heiyeluren  [gender] => 男  [2] => 男  [time] => 2006-10-28 23:14:23  [3] => 2006-10-28 23:14:23 ) }   我们看里面的记录,数字索引和关联索引都有,浪费资源,我们只需要关联索引的: <?php $db->setAttribute(PDO::ATTR_CASE, PDO::CASE_UPPER); $rs = $db->query("SELECT * FROM foo"); $rs->setFetchMode(PDO::FETCH_ASSOC); $result_arr = $rs->fetchAll(); print_r($result_arr); ?>   看上面的代码,setAttribute() 方法是设置部分属性,主要属性有:PDO::ATTR_CASE、PDO::ATTR_ERRMODE等等,我们这里需要设置的是PDO::ATTR_CASE,就是我们使用关联索引获取数据集的时候,关联索引是大写还是小写,有几个选择:   PDO::CASE_LOWER -- 强制列名是小写   PDO::CASE_NATURAL -- 列名按照原始的方式   PDO::CASE_UPPER -- 强制列名为大写   我们使用setFetchMode方法来设置获取结果集的返回值的类型,同样类型还有:   PDO::FETCH_ASSOC -- 关联数组形式   PDO::FETCH_NUM -- 数字索引数组形式   PDO::FETCH_BOTH -- 两者数组形式都有,这是缺省的   PDO::FETCH_OBJ -- 按照对象的形式,类似于以前的 mysql_fetch_object()   当然,一般情况下我们是使用PDO::FETCH_ASSOC,具体使用什么,按照你自己的需要,其他获取类型参考手册。   除了上面这种获取数据的方式,还有这种: <?php $rs = $db->prepare("SELECT * FROM foo"); $rs->execute(); while($row = $rs->fetch()){  print_r($row); } ?>   其实差不多啦。如果你想获取指定记录里一个字段结果的话,可以使用 PDOStatement::fetchColumn(): <?php $rs = $db->query("SELECT COUNT(*) FROM foo"); $col = $rs->fetchColumn(); echo $col; ?>   一般使用fetchColumn()来进行count统计或者某些只需要单字段的记录很好操作。   简单的总结一下上面的操作:   查询操作主要是PDO::query()、PDO::exec()、PDO::prepare()。PDO::query()主要是用于有记录结果返回的操作,特别是SELECT操作,PDO::exec()主要是针对没有结果集合返回的操作,比如INSERT、UPDATE、DELETE等操作,它返回的结果是当前操作影响的列数。PDO::prepare()主要是预处理操作,需要通过$rs->execute()来执行预处理里面的SQL语句,这个方法可以绑定参数,功能比较强大,不是本文能够简单说明白的,大家可以参考手册和其他文档。 获取结果集操作主要是:PDOStatement::fetchColumn()、PDOStatement::fetch()、PDOStatement::fetchALL()。PDOStatement::fetchColumn() 是获取结果指定第一条记录的某个字段,缺省是第一个字段。PDOStatement::fetch() 是用来获取一条记录,PDOStatement::fetchAll()是获取所有记录集到一个中,获取结果可以通过PDOStatement::setFetchMode来设置需要结果集合的类型。   另外有两个周边的操作,一个是PDO::lastInsertId()和PDOStatement::rowCount()。PDO::lastInsertId()是返回上次插入操作,主键列类型是自增的最后的自增ID。PDOStatement::rowCount()主要是用于PDO::query()和PDO::prepare()进行DELETE、INSERT、UPDATE操作影响的结果集,对PDO::exec()方法和SELECT操作无效。   【错误处理】   如果程序中碰到错误咋办?我们这里描述PDO类的错误信息和异常处理。   1. 面向对象的方式   先看看如果连接错误等的处理,使用面向对象的方式来处理: <?php try {  $db = new PDO('mysql:host=localhost;dbname=test', $user, $pass);  $db = null; } catch (PDOException $e) {  print "Error: " . $e->getMessage() . "<br/>";  die(); } ?>   这里利用我们PHP 5面向对象的异常处理特征,如果里面有异常的话就初始化调用PDOException来初始化一个异常类。   PDOException异常类的属性结构: <?php class PDOException extends Exception {  public $errorInfo = null; // 错误信息,可以调用 PDO::errorInfo() 或 PDOStatement::errorInfo()来访问  protected $message; // 异常信息,可以试用 Exception::getMessage() 来访问  protected $code; // SQL状态错误代码,可以使用 Exception::getCode() 来访问 } ?>   这个异常处理类是集成PHP 5内置的异常处理类,我们简单的看一下PHP 5内置的异常处理类结构: <?php class Exception {  // 属性  protected $message = 'Unknown exception'; // 异常信息  protected $code = 0; // 用户自定义异常代码  protected $file; // 发生异常的文件名  protected $line; // 发生异常的代码行号  // 方法  final function getMessage(); // 返回异常信息  final function getCode(); // 返回异常代码  final function getFile(); // 返回发生异常的文件名  final function getLine(); // 返回发生异常的代码行号  final function getTrace(); // backtrace() 数组  final function getTraceAsString(); // 已格成化成字符串的 getTrace() 信息 } ?>   相应的,在代码中可以合适的调用 getFile() 和 getLine() 来进行错误定位,更方便的进行调试。   2. 使用面向过程的方法   先看代码: <? $db = new PDO('mysql:host=localhost;dbname=test', $user, $pass); $rs = $db->query("SELECT aa,bb,cc FROM foo"); if ($db->errorCode() != '00000'){  print_r($db->errorInfo());  exit; } $arr = $rs->fetchAll(); print_r($arr); $db = null; ?>   PDO和PDOStatement对象有errorCode() 和 errorInfo() 方法,如果没有任何错误, errorCode() 返回的是: 00000 ,否则就会返回一些错误代码。errorInfo() 返回的一个数组,包括PHP定义的错误代码和MySQL的错误代码和错误信息,数组结构如下: Array (  [0] => 42S22  [1] => 1054  [2] => Unknown column 'aaa' in 'field list' )   每次执行查询以后,errorCode() 的结果都是最新的,所以我们可以很容易自己控制错误信息显示。   【简单总结】   从上面的使用看出,PDO功能确实强大,另外还有一些内容我没有讲到,比如绑定参数、预处理、存储过程、事务处理等等功能。另外还有不同数据扩 DSN的构造,Oracle数据库自己很多特殊的东西,都需要深入去学习理解,这篇文章就只是简单的描述了一些入门知识,算是对PDO一个简单的了解吧。 <?php $mysql_server_name='localhost'; $mysql_username='root'; $mysql_password='12345678'; $mysql_database='mycounter'; $conn=mysql_connect($mysql_server_name,$mysql_username,$mysql_password,$mysql_database); $sql='CREATE DATABASE mycounter DEFAULT CHARACTER SET gbk COLLATE gbk_chinese_ci; '; mysql_query($sql); $sql='CREATE TABLE `counter` (`id` INT(255) UNSIGNED NOT NULL AUTO_INCREMENT ,`count` INT(255) UNSIGNED NOT NULL DEFAULT 0,PRIMARY KEY ( `id` ) ) TYPE = innodb;'; mysql_select_db($mysql_database,$conn); $result=mysql_query($sql); //echo $sql; mysql_close($conn); echo "Hello!数据库mycounter已经成功建立!"; ?> php使用adodb连接mssql数据库代码 2010-09-13 15:27:19     我来说两句       收藏    我要投稿 php使用adodb连接mssql数据库代码 include_once(adodb5/adodb.inc.php); $conn=adonewconnection(odbc_mssql); $conn->pconnect("driver={sql server};server=dlut-pcsqlexpress;database=yuyan;",zhouhao,950288); $adodb_fetch_mode=adodb_fetch_assoc; $sqlstr=select * from yuyan where ps教程nno=?; $rst=$conn->execute($sqlstr,005) or die(connect error); while(!$rst->eof) {     //echo $rst->fields[ps教程nname].->.$rst->fields[psnno].;     echo dajiahao;     $rst->movenext(); } $rst->close(); $conn->close(); 几种常用PHP连接数据库的代码示例 2009-12-03 13:34 佚名 百度博客 字号:T | T 我们今天为大家介绍的PHP连接数据库的方法包括在MYSQL数据库,ACCESS数据库,MS SQL数据库和Oracle数据库中实现。 AD: 2014WOT全球软件技术峰会北京站 课程视频发布 PHP语言经常被程序员用来开发网站,在实际操作中肯定会与数据库打上交道。今天我们就为大家介绍有关PHP连接数据库的各种方法,希望对大家有用。 · 解读PHP函数strrev()以外的三种逆序排列 · PHP自定义异常处理器的几种使用方法 · 如何正确实现PHP网站优化 · 教你如何正确安装phpDocumentor · 如何正确配置PHP开发环境 PHP连接数据库之PHP连接MYSQL数据库代码 1. < ?php    2. $mysql_server_name='localhost';  3. //改成自己的mysql数据库服务器   4. $mysql_username='root';  5. //改成自己的mysql数据库用户名   6. $mysql_password='12345678';  7. //改成自己的mysql数据库密码   8. $mysql_database='mycounter'; 9.  //改成自己的mysql数据库名   10. $conn=mysql_connect($mysql_server_name, $mysql_username,$mysql_password, $mysql_database);    11. $sql='CREATE DATABASE mycounter  DEFAULT CHARACTER SET gbk COLLATE gbk_chinese_ci;    12. ';    13. mysql_query($sql);    14. $sql='CREATE TABLE `counter`  (`id` INT(255) UNSIGNED NOT NULL  AUTO_INCREMENT ,`count` INT(255)  UNSIGNED NOT NULL DEFAULT 0,PRIMARY KEY  ( `id` ) ) TYPE = innodb;';    15. mysql_select_db($mysql_database,$conn);    16. $result=mysql_query($sql);    17. //echo $sql;    18. mysql_close($conn);    19. echo "Hello!数据库mycounter已经成功建立!";    20. ?>  PHP连接数据库之PHP连接ACCESS数据库代码方法 1. < ?   2. $conn = new com("ADODB.Connection");    3. $connstr = "DRIVER={Microsoft  Access Driver (*.mdb)};  DBQ=". realpath("data/db.mdb");    4. $conn->Open($connstr);    5. $rs = new com("ADODB.RecordSet");    6. $rs->Open("select *  from szd_t",$conn,1,1);    7. while(! $rs->eof) {    8. $f = $rs->Fields(1);    9. echo $f->value;    10. $rs->MoveNext();    11. }    12. ?>  PHP连接数据库之PHP连接MS SQL数据库代码方法 1.安装SQL服务器并添加PHP的MSSQL扩展 2.使用以下代码连接并测试 1. < ?php    2. $myServer = localhost; //主机   3. $myUser = sa; //用户名   4. $myPass = password; //密码   5. $myDB = Northwind; //MSSQL库名   6. $s = @mssql_connect($myServer,  $myUser, $myPass)    7. or die(Couldnt connect to  SQL Server on $myServer);    8. $d = @mssql_select_db($myDB, $s)    9. or die(Couldnt open database $myDB);    10. $query = SELECT TitleOfCourtesy + +FirstName+ +LastName AS Employee ;    11. $query .= FROM Employees ;    12. $query .= WHERE Country=USA  AND Left(HomePhone, 5) = (206);    13. $result = mssql_query($query);    14. $numRows = mssql_num_rows($result);    15. echo < h1> . $numRows . Row .  ($numRows == 1 ? : s) . Returned </ h1>;    16. while($row = mssql_fetch_array($result))    17. {    18. echo <
展开阅读全文

开通  VIP会员、SVIP会员  优惠大
下载10份以上建议开通VIP会员
下载20份以上建议开通SVIP会员


开通VIP      成为共赢上传
相似文档                                   自信AI助手自信AI助手

当前位置:首页 > 包罗万象 > 大杂烩

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        抽奖活动

©2010-2025 宁波自信网络信息技术有限公司  版权所有

客服电话:4009-655-100  投诉/维权电话:18658249818

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :微信公众号    抖音    微博    LOFTER 

客服