php数据库连接时如何带参数,PHP扩展数据库连接参数说明详解

名词解释:

mysqli,mysqlnd,pdo到底是什么?,有什么用途?MySQL: This extension is deprecated as of PHP 5.5.0, and has been removed as of php 7.0.0.

MYSQLI:  mysql Improved Extension

MySQLND: MySQL Native Drive

PDO:The PHP Data Objects。extension defines a lightweight, consistent interface for accessing databases in PHP。

以下为中文翻译:

MYSQL 也叫 Original MySQL,PHP4版本的MYSQL扩展,从PHP5起已经被废弃,并从PHP7中移除。

MYSQLI 叫做 “MySQL增强扩展”。

MYSQLND MYSQL NATIVE DIRVER 叫做MYSQL “官方驱动”或者更加直接点的叫做“原生驱动”

PDO   PHP Data Objects PHP数据对象,是PHP应用中的一个数据库抽象层规范。

再补充几个名词解释:

1 、什么是API?一个应用程序接口(Application Programming Interface的缩写),定义了类,方法,函数,变量等等一切

你的应用程序中为了完成特定任务而需要调用的内容。在PHP应用程序需要和数据库进行交互的时候所需要的API

通常是通过PHP扩展暴露出来(给终端PHP程序员调用)。

上文所说的MYSQL 和MYSQLI扩展就提供了这样的API。

2、什么是驱动?驱动是一段设计用来于一种特定类型的数据库服务器进行交互的软件代码。驱动可能会调用一些库,

比如MySQL客户端库或者MySQL Native驱动库。 这些库实现了用于和MySQL数据库服务器进行交互的底层协议。

从PHP拓展的角度上看,MYSQL和MYSQLi还是比较上层的拓展,依赖更底层的库去连接和访问数据库。

上文所说的MYSQLND 就是所说的底层的数据库驱动。当然,还有一个驱动叫做libmysqlclient。

小结:

从应用的层面上看,我们通过PHP 的MYSQL或者MYSQLi扩展提供的API去操作数据库。

从底层来看,MYSQLND提供了底层和数据库交互的支持(可以简单理解为和MySQL server进行网络协议交互)。

而PDO,则提供了一个统一的API接口,使得你的PHP应用不去关心具体要连接的数据库服务器系统类型。也就是说,如果你使用PDO的API,可以在任何需要的时候无缝切换数据库服务器。比如MYSQL,SQLITE任何数据库都行。

即从大部分功能上看,PDO提供的API接口和MYSQLI提供的接口对于普通的增删改查效果是一致的。

通过PHP代码理解:MYSQL连接:<?php

$conn = @ mysql_connect("localhost", "root", "") or die("数据库连接错误");

mysql_select_db("bbs", $conn);

mysql_query("set names ‘utf8‘");

echo "数据库连接成功";

?>

MYSQLI连接:<?php

$conn = mysqli_connect(‘localhost‘, ‘root‘, ‘‘, ‘bbs‘);

if(!$conn){

die("数据库连接错误" . mysqli_connect_error());

}else{

echo"数据库连接成功";

}

?>

PDO连接:<?php

try{

$pdo=new pdo("mysql:host=localhost;dbname=bbs","root","");

}catch(PDDException $e){

echo"数据库连接错误";

}

echo"数据库连接成功";

?>

注意常用参数

--enable-pdo

--with-pdo-mysql

--enable-mysqlnd

--with-mysqli

--with-mysql      //php7的已经不再支持,无论是编译还是yum安装都会报ERROR

原文:http://461205160.blog.51cto.com/274918/1943416

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值