Heim >Backend-Entwicklung >PHP-Tutorial >php连接mysql~高手略过

php连接mysql~高手略过

WBOY
WBOYOriginal
2016-06-23 13:46:49984Durchsuche

最近在linux装了新的环境,php5.6+mysql5.5+nginx。然后用原来的mysql链接数据库出现的错误。

原因就是说连接数据库的方法太旧。建议我用mysqli和PDO来链接数据库。

好吧,咱也不能落后,使用mysqli的确也简单了不少,但是PDO貌似更简单。效率也会得到提升。根据官方文档,貌似对于sql注入的一些风险也做了屏蔽。所以今天写的 博客就是关于php用PDO连接mysql的一些介绍啦!


【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基于php的版本:

PDO 是 PHP 5.1 发行的,也就是说,在 5.1 之前的版本是不支持 PDO。在PHP5.0的PECL扩展中也可以使用。


PDO如何使用:

这里我们就以PHP的黄金搭档mysql作为例子看看:

     PDO_MYSQL:PDO_MYSQL是PDO接口能够完成连接mysql数据库的驱动(注:仅使用于mysql 3.x以上版本)。

安装:打开php.ini文件,可以找到如下代码,这里可以看到mysql的驱动默认已经打开(前面没有用于注释的分号),如有连接其他数据库的需要,自行添加其他数据库的驱动程序(取出相应的项前面的分号,没有的添上)。

    //各数据库的PDO驱动      extension=php_pdo.dll       extension=php_pdo_firebird.dll //Firebird      extension=php_pdo_informix.dll //Informix      extension=php_pdo_mssql.dll    //sql server      extension=php_pdo_mysql.dll    //mysql      extension=php_pdo_oci.dll      //Oracle      extension=php_pdo_oci8.dll       extension=php_pdo_odbc.dll     //DB2      extension=php_pdo_pgsql.dll    //PostgreSQL      extension=php_pdo_sqlite.dll   //SQLite  

连接:通过创建PDO基类的实例创建连接。

    //连接到数据库      $db = new PDO('mysql:host=localhost;dbname=test', $user, $pass);  

//处理连接错误  try {      $db = new PDO('mysql:host=localhost;dbname=test', $user, $pass);      //查询      foreach($db->query('SELECT * from FOO') as $row) {          print_r($row);      }      $dbh = null;  } catch (PDOException $e) {      print "Error!: " . $e->getMessage() . "<br>";      die();  }


//关闭连接  $db = null; 

PDO方式连接数据库mysql的实例:

<?php $dbms='mysql';       //数据库 mysql    $host='localhost';   //数据库主机名    $dbName='test';      //数据库名    $user='root';        //连接用户名    $pass='';            //密码    $dsn="$dbms:host=$host;dbname=$dbName";    classdbextendsPDO{       publicfunction__construct(){            try{                parent::__construct("$GLOBALS[dsn]",$GLOBALS['user'],$GLOBALS['pass']);             }catch(PDOException$e){                 die("Error: ".$e->__toString()."<br>");            }       }       publicfinalfunctionquery($sql){            try{                returnparent::query($this->setString($sql));            }catch(PDOException$e){                die("Error: ".$e->__toString()."<br>");            }       }       privatefinalfunctionsetString($sql){            echo"处理查询";            return $sql;       }    }    $db=new db();    $db->setAttribute(PDO::ATTR_CASE,PDO::CASE_UPPER);    foreach($db->query('select * from table_name') as $row){       print_r($row);    }    $db->exec('delete from table_name where id=11');?>


更多的PDO方法:

    PDO::beginTransaction ? 启动一个事务      PDO::commit ? 提交一个事务      PDO::__construct ? 创建一个表示数据库连接的 PDO 实例      PDO::errorCode ? 获取跟数据库句柄上一次操作相关的 SQLSTATE      PDO::errorInfo ? Fetch extended error information associated with the last operation on the database handle      PDO::exec ? 执行一条 SQL 语句,并返回受影响的行数      PDO::getAttribute ? 取回一个数据库连接的属性      PDO::getAvailableDrivers ? 返回一个可用驱动的数组      PDO::inTransaction ? 检查是否在一个事务内      PDO::lastInsertId ? 返回最后插入行的ID或序列值      PDO::prepare ? Prepares a statement for execution and returns a statement object      PDO::query ? Executes an SQL statement, returning a result set as a PDOStatement object      PDO::quote ? Quotes a string for use in a query.      PDO::rollBack ? 回滚一个事务      PDO::setAttribute ? 设置属性  

PDOStatement::bindColumn ? 绑定一列到一个 PHP 变量  PDOStatement::bindParam ? 绑定一个参数到指定的变量名  PDOStatement::bindValue ? 把一个值绑定到一个参数  PDOStatement::closeCursor ? 关闭游标,使语句能再次被执行。  PDOStatement::columnCount ? 返回结果集中的列数  PDOStatement::debugDumpParams ? 打印一条 SQL 预处理命令  PDOStatement::errorCode ? 获取跟上一次语句句柄操作相关的 SQLSTATE  PDOStatement::errorInfo ? 获取跟上一次语句句柄操作相关的扩展错误信息  PDOStatement::execute ? 执行一条预处理语句  PDOStatement::fetch ? 从结果集中获取下一行  PDOStatement::fetchAll ? 返回一个包含结果集中所有行的数组  PDOStatement::fetchColumn ? 从结果集中的下一行返回单独的一列。  PDOStatement::fetchObject ? 获取下一行并作为一个对象返回。  PDOStatement::getAttribute ? 检索一个语句属性  PDOStatement::getColumnMeta ? 返回结果集中一列的元数据  PDOStatement::nextRowset ? 在一个多行集语句句柄中推进到下一个行集  PDOStatement::rowCount ? 返回受上一个 SQL 语句影响的行数  PDOStatement::setAttribute ? 设置一个语句属性  PDOStatement::setFetchMode ? 为语句设置默认的获取模式。 

    Exception::getMessage ? 获取异常消息内容。      Exception::getPrevious ? 返回异常链中的前一个异常      Exception::getCode ? 获取异常代码      Exception::getFile ? 获取发生异常的程序文件名称      Exception::getLine ? 获取发生异常的代码在文件中的行号      Exception::getTrace ? 获取异常追踪信息      Exception::getTraceAsString ? 获取字符串类型的异常追踪信息      Exception::toString ? 将异常对象转换为字符串      Exception::clone ? 异常克隆  



Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Vorheriger Artikel:thinkphp去掉index.phpNächster Artikel:phpunit