服务器之家:专注于服务器技术及软件下载分享
分类导航

Mysql|Sql Server|Oracle|Redis|

服务器之家 - 数据库 - Mysql - mysql与mysqli的区别与用法说明

mysql与mysqli的区别与用法说明

2019-11-08 15:21mysql教程网 Mysql

mysql是非持继连接函数而mysqli是永远连接函数。

也就是说 

mysql每次链接都会打开一个连接的进程而mysqli多次运行mysqli将使用同一连接进程,从而减少了服务器的开销 

有些朋友在编程的时候,使用new mysqli('localhost', usenamer', 'password', 'databasename');总是报错,Fatal error: Class 'mysqli' not found in d:\... 
mysqli类不是php自带的吗? 

不是默认开启的,win下要改php.ini,去掉php_mysqli.dll前的;,linux下要把mysqli编译进去 

mysql是非持继连接函数而mysqli是永远连接函数,也就是说 

mysql每次链接都会打开一个连接的进程而mysqli多次运行mysqli将使用同一连接进程,从而减少了服务器的开销 
有些朋友在编程的时候,使用new mysqli('localhost', usenamer', 'password', 'databasename');总是报错,Fatal error: Class 'mysqli' not found in d:\... 
mysqli类不是php自带的吗? 

不是默认开启的,win下要改php.ini,去掉php_mysqli.dll前的;,linux下要把mysqli编译进去 
mysqli的面向过程的使用: 

复制代码代码如下:


$conn = mysqli_connect('localhost', 'root', '123', 'db_test') or ('error'); 
$sql = "select * from db_table"; 
$query = mysqli_query($conn,$sql); 
while($row = mysqli_fetch_array($query)){ 
echo $row['title']; 


mysqli的面向对象的使用: 

复制代码代码如下:


$conn = mysqli('localhost', 'root', '123', 'db_test'); 
$sql = "select * from db_table"; 
$query = $conn->query($sql); 
while($row = $query->fetch_array()){ 
echo $row['title']; 


mysql_pconnect打开的连接不会关闭(即使调用mysql_close也不会关闭,因为对其无效), 
类似于连接缓冲池,如果下次有来自于同一个机器的同一个用户名 
对同一个数据库的连接,php会自动使用上次已经建立的连接,而不需要再重新建立一个。 
好处:是省去了每次与数据库建立连接的开销, 
坏处:是需要浪费一些内存,占用一些连接, 
所以如果用户访问量大的时候会出现错误,要把mysql的max_connections参数改大一点, 或者使用mysql_connect()就解决问题。 

首先两个函数都是用来处理DB 的。 

首先, mysqli 连接是永久连接,而mysql是非永久连接。什么意思呢? mysql连接每当第二次使用的时候,都会重新打开一个新的进程,而mysqli则只使用同一个进程,这样可以很大程度的减轻服务器端压力。 
其次,mysqli封装了诸如事务等一些高级操作,同时封装了DB操作过程中的很多可用的方法。具体查看 http://cn.php.net/mysqli 

应用比较多的地方是 mysqli的事务。 
比如下面的示例: 

复制代码代码如下:


$mysqli = new mysqli('localhost','root','','DB_Lib2Test'); 
$mysqli->autocommit(false);//开始事物 
$mysqli->query($sql1); 
$mysqli->query($sql2); 
if(!$mysqli->errno){ 
$mysqli->commit(); 
echo 'ok'; 
}else{ 
echo 'err'; 
$mysqli->rollback(); 

延伸 · 阅读

精彩推荐
  • MysqlMySQL slow_log表无法修改成innodb引擎详解

    MySQL slow_log表无法修改成innodb引擎详解

    这篇文章主要给大家介绍了关于MySQL slow_log表无法修改成innodb引擎的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用MySQL具有一定的参考...

    Jia-Xin1702019-06-25
  • MysqlMySQL JOIN之完全用法

    MySQL JOIN之完全用法

    最近在做mysql的性能忧化,做到多表连接查询,比较头疼,看了一些join的资料,终于搞定,这里分享出来! ...

    mysql教程网4022019-11-04
  • Mysqlmysql SELECT语句去除某个字段的重复信息

    mysql SELECT语句去除某个字段的重复信息

    mysql SELECT语句去除某个字段的重复信息,需要的朋友可以收藏下。 ...

    mysql教程网1252019-11-06
  • MysqlSQL 优化

    SQL 优化

    (一)深入浅出理解索引结构 实际上,您可以把索引理解为一种特殊的目录。微软的 SQL SERVER提供了两种索引:聚集索引(clustered index,也称聚类索引、簇集索...

    mysql技术网2842019-10-15
  • Mysql解决MySQL数据库中文模糊检索问题的方法

    解决MySQL数据库中文模糊检索问题的方法

    在 MySQL 下,在进行中文模糊检索时,经常会返回一些与之不相关的记录,如查找%a%时,返回的可能有中文字符,却没有a字符存在。本人以前也曾遇到过类...

    mysql教程网4522019-10-18
  • MysqlMySQL 相关的环境变量

    MySQL 相关的环境变量

    所有使用mysqlclient客户库与服务器通信的MySQL客户使用下列环境变量 ...

    mysql教程网3732019-10-29
  • MysqlLinux中 MySQL 授权远程连接的方法步骤

    Linux中 MySQL 授权远程连接的方法步骤

    如果需要远程连接 Linux 系统上的 MySQL 时,必须为其 IP 和 具体用户 进行 授权,本篇文章主要介绍了Linux中 MySQL 授权远程连接的方法步骤,感兴趣的小伙伴...

    斯文败类i1452019-06-22
  • Mysql在Windows平台上升级MySQL注意事项

    在Windows平台上升级MySQL注意事项

    在Windows平台上升级MySQL注意事项 ...

    mysql教程网2032019-10-20