加入收藏 | 设为首页 | 会员中心 | 我要投稿 聊城站长网 (https://www.0635zz.com/)- 智能语音交互、行业智能、AI应用、云计算、5G!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

mysqli和mysql的区别有什么

发布时间:2023-04-30 13:31:26 所属栏目:MySql教程 来源:
导读:这篇文章主要介绍“mysqli和mysql的区别有哪些”,在日常操作中,相信很多人在mysqli和mysql的区别有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”mysqli和m
这篇文章主要介绍“mysqli和mysql的区别有哪些”,在日常操作中,相信很多人在mysqli和mysql的区别有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”mysqli和mysql的区别有哪些”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
 
区别:1、mysqli连接是永久连接,而mysql是非永久连接;2、mysql连接每当第二次使用时,都会重新打开一个新的进程,而mysqli连接一直都只使用同一个进程。
 
本教程操作环境:windows7系统、mysql8版本、Dell G3电脑。
 
一、mysql与mysqli的区别:
 
mysqli连接是永久连接,而mysql是非永久连接。
 
mysql连接:每当第二次使用的时候,都会重新打开一个新的进程。
 
mysqli连接:一直都只使用同一个进程。
 
好处:这样就可以很大程度的减轻服务器端压力。
 
当然,如果mysql也需要永久连接的话,就可以使用mysql_pconnect()这个函数
 
二、mysqli的使用:
 
1、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'];
 
}
 
2、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与mysqli_connect:
 
1、mysql_pconnect打开的连接不会关闭(即使调用mysql_close也不会关闭,因为对其无效),类似于连接缓冲池,如果下次有来自于同一个机器的同一个用户名对同一个数据库的连接,php会自动使用上次已经建立的连接,而不需要再重新建立一个。
 
好处:是省去了每次与数据库建立连接的开销,
 
坏处:是需要浪费一些内存,占用一些连接,
 
所以如果用户访问量大的时候会出现错误,要把mysql的max_connections参数改大一点, 或者使用mysql_connect()就解决问题。
 
2、简单的来说MySQL_pconnect是用来在php与MySQL间建立一条持续连接,一般php的执行模式是脚本开始执行时初始化所有资源, 脚本运行结束后释放所有资源。
 
而MySQL_pconnect的方式则不这样, MySQL_connect每次都是重新通过tcp 等跟sql服务器建立关系, 每次连接都是要消耗不少服务器资源的。
 
3、使用pconnect时,有请求连接MySQL时,php会检查是否之前有条相同的连接(以相同的用户名密码连接到同一个MySQL服务器)已经建立,如果有的话就直接使用这条连接,值得注意的是这个相同的连接的概念是对进程来说的,不同的进程连接MySQL_pconnect建立会建立起多条连接。
 
4、connect与pconnect不会带来功能的差异,只有性能上的差别。
 
5、一般php有俩种运行模式,一是作为cgi运行, 二是作为apache的模块运行。
 
6、作为cgi的时候connect跟pconnect没什么不同,因为每次cgi进行运行结束后都会被销毁清理掉资源.
 
 

(编辑:聊城站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!