● mysql_result():优点在于使用方便;而缺点在于功能少,一次调用只能获取结果数据集中的一行记录,对较大型的数据库效率较低.
● mysql_fetch_array():执行效率同样很高,同mysql_fetch_row()相差无几,并且可以用属性名方式直接获取得属性值,所以呢,在实际应用中最常用.
● mysql_fetch_object():采用了面向对象的思想,在设计思路上更为先进,如果读者习惯于面向对象的思路来写程序,则会很自然的选择它.其次,该方法的优点还体现在,对于结构较为复杂的数据结果,在逻辑上显得更为清晰.
首先说下,题主这个问题不是函数释放的问题
问题在于 require_once
第一次:在get_config内 第一次 引入 conf.php 赋值给 $conf , 此时 $conf 得到期望 数组 ,没有任何问题.
(注:此时已经在本次运行环境中引入了conf.php)
第二次:在get_config内再次尝试引入 conf.php 此时 require_once 会检测到运行环境中已经引入了该文件,此时返回值为 true 对 true 进行取值 肯定是 null
题主正确的做法是把 require_once 放入全局GLOBALS内,在 get_config 内引入全局变量即可.
修改后的代码:
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的时候 为啥受上一次函数的影响
mysql查询结果句柄会消耗内存.为了节约内存,在使用完毕后可以手动释放.不过一般情况下不需要这么做,程序结束会自动释放的.
这里的$pageCount变量存在.因为释放mysql句柄$res和$pageCount无关.
以下方法可以释放$pageCount:
unset($pageCount);
望采纳,谢谢支持!
不需要手动释放,当执行完这个页面的脚本后,$res这个变量会自动销毁,数据库连接会在语句执行完成后断开.
例如,在任一控制器的任一方法内写入下列代码
if(I("get.a")){
$a = I("get.a");
dump($a);
}else{
第一次打开这个页面时加上a=1的参数,会输出1,然后把参数去掉,会输出空或未定义的变量.
下面是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函数是释放结果集相关主题介绍,如果您觉得小编更新的文章只要能对粉丝们有用,就是我们最大的鼓励和动力,不要忘记讲本站分享给您身边的朋友哦!!