Login
网站首页 > 文章中心 > 其它

php函数是释放结果集_下列选项

作者:小编 更新时间:2023-08-01 14:26:18 浏览量:372人看过

php获取结果集的几个方法

● mysql_result():优点在于使用方便;而缺点在于功能少,一次调用只能获取结果数据集中的一行记录,对较大型的数据库效率较低.

● mysql_fetch_array():执行效率同样很高,同mysql_fetch_row()相差无几,并且可以用属性名方式直接获取得属性值,所以呢,在实际应用中最常用.

● mysql_fetch_object():采用了面向对象的思想,在设计思路上更为先进,如果读者习惯于面向对象的思路来写程序,则会很自然的选择它.其次,该方法的优点还体现在,对于结构较为复杂的数据结果,在逻辑上显得更为清晰.

php函数是释放结果集_下列选项-图1

php 函数运行完了 不就释放了吗,还要等脚本结束

首先说下,题主这个问题不是函数释放的问题

问题在于 require_once

第一次:在get_config内 第一次 引入 conf.php 赋值给 $conf , 此时 $conf 得到期望 数组 ,没有任何问题.

(注:此时已经在本次运行环境中引入了conf.php)

第二次:在get_config内再次尝试引入 conf.php 此时 require_once 会检测到运行环境中已经引入了该文件,此时返回值为 true 对 true 进行取值 肯定是 null

题主正确的做法是把 require_once 放入全局GLOBALS内,在 get_config 内引入全局变量即可.

php函数是释放结果集_下列选项-图2

修改后的代码:

a.php

$GLOBALS['conf'] = require_once 'conf.php';

function get_config($key, $default = null){

return isset($GLOBALS['conf'][$key])

$GLOBALS['conf'][$key]

: $default;

}

var_dump(get_Config('name'));

var_dump(get_Config('age'));

--- 共有 1 条评论 ---

题主这个config的格式不需要把引入的文件赋值,只需要require_once就可以了

①. function get_config($key){

conf.php

①. $config=array(

引用来自"梁上有木"的评论

function get_config($key){

require_once 'conf.php';

return $conf[$key];

里$conf是啥,

是a.php里的 $config吧

就算是

第二次调用 也是不行的

终于明白为什么php 的排名日落千丈了.

各种乱入,各种小白啊,贵圈太乱了...

都是想当然地写代码...require_once 你赋值干嘛...而且你这种写法很粗糙,也很dirty,你造吗?

推荐写法:

$config = call_user_func(function() {

return include 'config.php';

});

引用来自"D哥"的评论

谢谢!,我在函数里用静态变量也可以,您这也是一种方法

我仍不理解的是:第二次 执行时,既然它已经检测到 已经引入了该文件,那我直接用conf.php 里的 $config为啥也不行啊

我最不明白的是 函数里的 require_once 对正在执行这个函数的文件的影响,下次再require_once的时候 为啥受上一次函数的影响

关于php中释放资源mysql_free_result函数,释放资源是什么意思,是不是把mysql_query结果集中的值清空?

mysql查询结果句柄会消耗内存.为了节约内存,在使用完毕后可以手动释放.不过一般情况下不需要这么做,程序结束会自动释放的.

这里的$pageCount变量存在.因为释放mysql句柄$res和$pageCount无关.

以下方法可以释放$pageCount:

unset($pageCount);

望采纳,谢谢支持!

Thinkphp 是否需要手动释放结果集?

不需要手动释放,当执行完这个页面的脚本后,$res这个变量会自动销毁,数据库连接会在语句执行完成后断开.

例如,在任一控制器的任一方法内写入下列代码

if(I("get.a")){

$a = I("get.a");

dump($a);

}else{

第一次打开这个页面时加上a=1的参数,会输出1,然后把参数去掉,会输出空或未定义的变量.

PHP管理内存函数?memory_get_usage()使用介绍

下面是PHP

memory_get_usage()使用示例:

复制代码

代码如下:

echo

memory_get_usage(),

'br

/';

$tmp

=

str_repeat('',

unset($tmp);

memory_get_usage();

上面的程序后面的注释代表了它们的输出(单位为

byte(s)),也就是当时

PHP

脚本使用的内存(不含

memory_get_usage()

函数本身占用的内存)

由上面的例子可以看出,要想减少内存的占用,可以使用

unset()

函数把不再需要使用的变量删除.类似的还有:PHP

mysql_free_result()

函数,可以清空不再需要的查询数据库得到的结果集,这样也能得到更多可用内存.

memory_get_usage()还可以有个参数,$real_usage,其值为布尔值.默认为

FALSE,表示得到的内存使用量不包括该函数(PHP

内存管理器)占用的内存;当设置为

TRUE

时,得到的内存为包括该函数(PHP

内存管理器)占用的内存.

所以在实际编程中,可以用PHP

memory_get_usage()比较各个方法占用内存的高低,来选择使用哪种占用内存小的方法.

常用的检测:

用microtime函数就可以分析程序执行时间

memory_get_usage可以分析内存占用空间

SQL的效率可以使用打开慢查询查看日志分析

SQL

找到有瓶颈的使用EXPLAIN

来分析

以上就是土嘎嘎小编为大家整理的php函数是释放结果集相关主题介绍,如果您觉得小编更新的文章只要能对粉丝们有用,就是我们最大的鼓励和动力,不要忘记讲本站分享给您身边的朋友哦!!

版权声明:倡导尊重与保护知识产权。未经许可,任何人不得复制、转载、或以其他方式使用本站《原创》内容,违者将追究其法律责任。本站文章内容,部分图片来源于网络,如有侵权,请联系我们修改或者删除处理。

编辑推荐

热门文章