前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >变量类型测试函数的使用:七、is_resource的用法

变量类型测试函数的使用:七、is_resource的用法

原创
作者头像
大脸猫
修改2020-07-06 17:41:26
5560
修改2020-07-06 17:41:26
举报
文章被收录于专栏:全能大脸猫全能大脸猫

讲完PHP变量类型测试函数【is_object】的用法,今天来讲讲PHP变量类型测试函数【is_resource】的用法。

变量类型测试函数的使用:七、is_resource的用法
变量类型测试函数的使用:七、is_resource的用法

is_resource

is_resource — 检测变量是否为资源类型

is_resource 描述

is_resource ( mixed $var ) : bool

「is_resource函数参数和前六个变量测试函数的用法是一模一样的可以混合类型“混合类型:一个参数可以接受多种不同的类型”;返回结果也一样返回布尔类型 TRUE或者FALSE」

如果给出的参数 var 是 resource (资源)类型,is_resource() 返回 TRUE,否则返回 FALSE。

is_resource 实例

<?php

$fh = fopen(‘demo.txt‘,‘r‘);

if (is_resource($fh)){

echo "文件打开成功…";

}else{echo "打开文件错误";}

?>

输出结果为:文件打开成功...

关于is_resource()方法的问题问题

碰到的问题如下

在将php5.3的程序向php7迁移过程中 出现这样的问题:

1、我将mysql全换成mysqli

2、在判断mysql结果集时正确,能够正常得到结果,但是换成mysqli后也能够得到结果

现在问题原因是

换成mysqli后,is_resource()方法判断mysqli结果集的结果为false

上源代码 代码出自某商城程序

static function sqlOfUpdate(&$rs, $data, $InsertIfNoResult = false,$insertData=null,$ignore=false){

$db = kernel::database();

var_dump($rs,is_resource($rs['rs']));exit;

if(!is_resource($rs['rs'])){

trigger_error('SqlOfUpdate: '.$rs['sql'].' error ',E_USER_ERROR);}

@mysqli_data_seek($rs['rs'],0);

$row = mysqli_fetch_assoc($rs['rs']);

if($InsertIfNoResult && !$row){

return self::getinsertsql($rs,$data);}

输出的结果

array(2) {//$rs["rs"]=>object(mysqli_result)#74 (5) {["current_field"]=>int(0)["field_count"]=>int(4)["lengths"]=>NULL["num_rows"]=>int(0)["type"]=>int(0)}["sql"]=>string(115) "select * from `sdb_base_cache_expires` where 1 AND `type` = "DB" AND `app` = "base" AND `name` = "BASE_APP_CONTENT""}bool(false)//is_resource($rs['rs'])

resource类型中存在mysql结果类型而不存在mysqli结果类型

mysqli的结果集是一个对象,使用is_resource函数当然是false,没什么好纠结的

在这种情况更适合使用is_object

今天就分享到这里,拜拜我是你们的大朋友计算机爱好者大脸猫。

今日问题:【文章没人看我还在写,我能坚持多久?】

今日推荐:

变量类型测试函数的使用:六、is_object的用法

PHP变量类型测试函数的使用:五、is_array的用法

PHP变量类型测试函数的使用:四、is_string的用法

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • is_resource
  • is_resource 描述
  • is_resource 实例
  • 关于is_resource()方法的问题问题
相关产品与服务
云数据库 SQL Server
腾讯云数据库 SQL Server (TencentDB for SQL Server)是业界最常用的商用数据库之一,对基于 Windows 架构的应用程序具有完美的支持。TencentDB for SQL Server 拥有微软正版授权,可持续为用户提供最新的功能,避免未授权使用软件的风险。具有即开即用、稳定可靠、安全运行、弹性扩缩等特点。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档