MySQL的三种连接方式对比

  • PHP连接MySQL的三种方式:

    • PHP的MySQL扩展:面向过程的扩展,早期PHP连接MySQL的接口,主要针对MySQL4.1.3或更早版本,如今已被MySQLi取代;

//设置数据库参数
define('DB_USER','root');
define('DB_PASSWORD','123456');
define('DB_HOST','localhost');
define('DB_NAME','testdb');
//初始化数据库
if(!conn = @mysqli_connect(DB_HOST,DB_USER,DB_PASSWORD)){
    exit('数据库连接失败'.mysql_error());
}
//连接数据库
if(!mysql_select_db(DB_NAME)){
    exit('连接数据库失败'.mysql_error());
}
//设置字符集
if(!mysql_query('SET NAMES UTF8')){
    exit('字符集设置失败'.mysql_error());
}

 

  • PHP的MySQLi扩展:面向对象的高级扩展,支持MySQL4.1.3+版本,支持新版本的特性,特点为:面向对象接口、prepared语句支持、多语句执行支持、事务支持、增强调试能力、嵌入式服务支持、预处理方式完全解决了sql注入的问题;缺点为:只支持MySQL数据库。
<?php 
//设置数据库参数  profile.inc.php
define('DB_USER','root');
define('DB_PASSWORD','123456');
define('DB_HOST','localhost');
define('DB_NAME','testdb');
?>

<?php 
//连接数据库 引入DB类   DB.class.php
class DB {
    static public function getDB(){
        //连接数据库并获取数据库对象句柄
        $mysqli = new mysqli(DB_HOST,DB_USER,DB_PASSWORD,DB_NAME);
        if($mysqli->mysqli_connect_errno()){
            exit('数据库连接失败'.$mysqli->mysqli_connect_error());
        }
        //设置字符集
        $mysqli->set_charset('utf8');
        return $mysqli;
    }
}
?>

<?php
//使用
require 'profile.inc.php';
require 'DB.class.php';
$mysqli = DB::getDB();
?>

 

  • PHP的数据对象(PDO:PHP Data Object):是PHP应用中的一个抽象层规范,PDO提供了一个统一的API使你的PHP应用不去关心连接的数据库服务器系统类型,只需要修改少量的PHP代码即可无缝切换数据库类型。特性支持与mysqli类似。
//PDO封装的DB类
class DB{
    public $_pdo;//存放PDO对象
    public function __construct(){
        try{
            //连接数据库
            $this->_pdo = new PDO('mysql:host=localhost;dbname=test','root','123456');
            //设置PDO报错为抛出异常
            $this->_pdo->setAttrbute(PDO::ATTR_ERRMODE,PDO::ATTR_EXCEPTION);
        }catch(PDOException $e){
            exit($e->getMessage());
        }
    }
}
//调用
$_pdo = new DB();

 

对比项

mysqli扩展

PDO

mysql扩展

引入的PHP版本

5.0

5.0

3.0

PHP5.x是否包含

MySQL开发状态

活跃

在PHP5.3中活跃

仅维护

在MySQL新项目中建议使用程度

建议-首选

建议

不建议

API的字符集支持

服务端prepare语句的支持情况

客户端prepare语句的支持情况

存储过程支持情况

多语句执行支持情况

大多数

是否支持MySQL4.1以上的功能

大多数

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值