mysql_close关闭哪个连接标识
这是一道古老的题目
请看代码,数据库关闭指令将关闭哪个连接标识?( )
$link1 =mysql_connect("localhost","root",""); $link2 = mysql_connect("localhost","root",""); mysql_close();
A.$link1
B.$link2
C.全部关闭
D.报错
根据知识储备,mysql_close在未指定连接标识时,是就近原则。
手册上也有说明
mysql_close() closes the non-persistent connection to the MySQL server that's associated with the specified link identifier. If link_identifier isn't specified, the last opened link is used.
所以答案应该是B。
再想想,似乎有哪里漏了,
If a second call is made to mysql_connect() with the same arguments, no new link will be established, but instead, the link identifier of the already opened link will be returned.
那么两次connect打开的应该是同一个连接标识,那么应该是一起关闭了吧?
所以选C???
没错,我就是闲的蛋疼,要挣扎着纠结这一个将要被淘汰的函数。于是又验证了一下。
$link1 = mysql_connect('localhost','root',''); $link2 = mysql_connect('localhost','root',''); print_r($link1); print_r($link2);//$link1和$link2一样,第二次未创建新连接,返回已经打开的连接标识 mysql_close(); //下面可以正常打test库里表都打印出来 mysql_select_db('test',$link2); $rs = mysql_query('show tables;',$link2); while ($row = mysql_fetch_assoc($rs)) { print_r($row); echo "<br />"; } //这个当然也能 mysql_select_db('test',$link1); $rs = mysql_query('show tables;',$link1); while ($row = mysql_fetch_assoc($rs)) { print_r($row); echo "<br />"; }
没错,mysql_close()谁也没关闭。
实际上,如果把mysql_close();修改为
<code>mysql_close($link1); 或者 mysql_close($link2);</code>
下面$link1,$link2仍然都是有效的
如果真要close,只有这样才好使,
mysql_close($link1); mysql_close($link2);
两个一起close。
这是为什么呢?为什么呢?
回复内容:
这是一道古老的题目
请看代码,数据库关闭指令将关闭哪个连接标识?( )
$link1 =mysql_connect("localhost","root",""); $link2 = mysql_connect("localhost","root",""); mysql_close();
A.$link1
B.$link2
C.全部关闭
D.报错
根据知识储备,mysql_close在未指定连接标识时,是就近原则。
手册上也有说明
mysql_close() closes the non-persistent connection to the MySQL server that's associated with the specified link identifier. If link_identifier isn't specified, the last opened link is used.
所以答案应该是B。
再想想,似乎有哪里漏了,
If a second call is made to mysql_connect() with the same arguments, no new link will be established, but instead, the link identifier of the already opened link will be returned.
那么两次connect打开的应该是同一个连接标识,那么应该是一起关闭了吧?
所以选C???
没错,我就是闲的蛋疼,要挣扎着纠结这一个将要被淘汰的函数。于是又验证了一下。
$link1 = mysql_connect('localhost','root',''); $link2 = mysql_connect('localhost','root',''); print_r($link1); print_r($link2);//$link1和$link2一样,第二次未创建新连接,返回已经打开的连接标识 mysql_close(); //下面可以正常打test库里表都打印出来 mysql_select_db('test',$link2); $rs = mysql_query('show tables;',$link2); while ($row = mysql_fetch_assoc($rs)) { print_r($row); echo "<br />"; } //这个当然也能 mysql_select_db('test',$link1); $rs = mysql_query('show tables;',$link1); while ($row = mysql_fetch_assoc($rs)) { print_r($row); echo "<br />"; }
没错,mysql_close()谁也没关闭。
实际上,如果把mysql_close();修改为
<code>mysql_close($link1); 或者 mysql_close($link2);</code>
下面$link1,$link2仍然都是有效的
如果真要close,只有这样才好使,
mysql_close($link1); mysql_close($link2);
两个一起close。
这是为什么呢?为什么呢?
楼主的测试很赞,确实如此,mysql_connect返回的肯定是一个引用,如楼主的测试说明该句柄不但有一个变量引用而且还有一个句柄引用(我自己随便命名的),mysql_close的时候释放句柄引用,然后检查该变量的所有句柄引用是不是都被释放了,如果是的话则对该变量进行内存回收处理。例如
<code>$a = 'Hello'; $b = &$a; $c = &$a; unset($a); echo $b . $c; //HelloHello 而不是 null</code>
这个测试代码说明了内存回收关于引用的处理,所以推测mysql_close也是类似的处理,但是与unset的管理目标是不同的(例如unset管理的是内存指针,mysql_close管理的是连接句柄指针?)
不过貌似研究这个已经完全没有价值了,相同的事情在mysqli系列函数上不会发生:
<code><?php $link1 = mysqli_connect('localhost', 'root'); $link2 = mysqli_connect('localhost', 'root'); mysqli_close($link1); print_r(mysqli_get_host_info($link1)); print_r(mysqli_get_host_info($link2));</code>
而且php5已经抛弃了mysql系列函数,因此就算是bug或者不良问题也不会被修复了,调用mysql_connect时应该能看到警告信息:该系列函数将会在未来停止使用。
感谢@incNick 回答,已采纳答案。
另外补充一些内容
就算只有有一个连接的情况
$link1 = mysql_connect('localhost','root',''); $result = mysql_close(); var_dump($result); mysql_select_db('test',$link1 ); $rs = mysql_query('show tables;',$link1 ); while ($row = mysql_fetch_assoc($rs)) { print_r($row); echo "<br />"; }
mysql_close()在未指定link_identifier的时候,返回结果是true,
Returns TRUE on success or FALSE on failure.
表示关闭成功,但实际其实也是没有关闭的,依然能依次打印库里的表,该连接可以使用。
所以说有时间手册也挺害人的。
mysqli_close(),在未指定link_identifier的情况下执行结果是false。
在多个连接的情况下,在指定link_identifier的情况下,可单独关闭$link1,$link2。
综上,link_identifier是必需的!!!!
现在不是用pdo,mysqli了么,mysql_connect 之类的不鼓励使用了

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

PHP 8.4 带来了多项新功能、安全性改进和性能改进,同时弃用和删除了大量功能。 本指南介绍了如何在 Ubuntu、Debian 或其衍生版本上安装 PHP 8.4 或升级到 PHP 8.4

Visual Studio Code,也称为 VS Code,是一个免费的源代码编辑器 - 或集成开发环境 (IDE) - 可用于所有主要操作系统。 VS Code 拥有针对多种编程语言的大量扩展,可以轻松编写

MySQL 8.4(截至 2024 年的最新 LTS 版本)中引入的主要变化之一是默认情况下不再启用“MySQL 本机密码”插件。此外,MySQL 9.0完全删除了这个插件。 此更改会影响 PHP 和其他应用程序

本教程演示了如何使用PHP有效地处理XML文档。 XML(可扩展的标记语言)是一种用于人类可读性和机器解析的多功能文本标记语言。它通常用于数据存储

字符串是由字符组成的序列,包括字母、数字和符号。本教程将学习如何使用不同的方法在PHP中计算给定字符串中元音的数量。英语中的元音是a、e、i、o、u,它们可以是大写或小写。 什么是元音? 元音是代表特定语音的字母字符。英语中共有五个元音,包括大写和小写: a, e, i, o, u 示例 1 输入:字符串 = "Tutorialspoint" 输出:6 解释 字符串 "Tutorialspoint" 中的元音是 u、o、i、a、o、i。总共有 6 个元

如果您是一位经验丰富的 PHP 开发人员,您可能会感觉您已经在那里并且已经完成了。您已经开发了大量的应用程序,调试了数百万行代码,并调整了一堆脚本来实现操作

PHP连接MySQL后页面空白,die()函数失效的原因分析在学习PHP和MySQL数据库连接的过程中,常常会遇到一些让人困惑...

CMS 代表内容管理系统。它是一种软件应用程序或平台,使用户能够创建、管理和修改数字内容,而无需先进的技术知识。 CMS 允许用户轻松创建和组织内容
