首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

mysqli_statement :: num_rows()返回错误的值

在这个问答内容中,我们要讨论的是mysqli_statement :: num_rows()函数。这个函数用于返回结果集中的行数,但是有时候会返回错误的值。

首先,我们需要了解mysqli_statement是一个PHP的MySQLi扩展中的一个类,它用于处理预处理语句。num_rows()是该类中的一个方法,用于返回结果集中的行数。

然而,在某些情况下,num_rows()可能会返回错误的值。这通常是因为在调用num_rows()之前,没有正确执行预处理语句或者没有正确绑定参数。

例如,以下代码可能会导致num_rows()返回错误的值:

代码语言:php
复制
$stmt = $mysqli->prepare("SELECT * FROM users WHERE username = ?");
$stmt->bind_param("s", $username);
$stmt->execute();
echo $stmt->num_rows;

在这个例子中,忘记在execute()之前调用store_result()方法,这将导致num_rows()返回错误的值。

为了解决这个问题,我们需要在调用num_rows()之前调用store_result()方法。例如:

代码语言:php
复制
$stmt->execute();
$stmt->store_result();
echo $stmt->num_rows;

这将确保num_rows()返回正确的结果集行数。

总之,mysqli_statement :: num_rows()函数在某些情况下可能会返回错误的值,这通常是因为在调用该函数之前没有正确执行预处理语句或绑定参数。为了解决这个问题,我们需要在调用num_rows()之前调用store_result()方法。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • 执行sql语句时候mysqli详解

    执行sql语句时候mysqli详解 1. 连接数据库 连接数据库有两种方式,一种是通过mysqli_connect()帮助函数,另一种是通过new mysqli()对象来实现 两者所需传的参数同样都是这些(注意先后顺序): host 数据库地址 数据库地址可以传入域名或ip地址,如localhost或者127.0.0.1 username 管理用户名 管理员账号,如: root password 管理员密码 管理员账号的密码 dtabases 要连接的数据 选择要连接的数据库 port 端口号 该参数如果不传,默认请求3306端口 2. 设置字符集 使用mysqli_set_charset($connect, 'utf8');函数设置 第一个参数为mysqli的对象,第二个参数为需要设置的字符集,注意mysql的字符集中的utf8没有中间的- 使用面向对象的方式创建 $connect = new mysqli('127.0.0.1', 'root', 'root', 'test', 8889);$connect->set_charset('utf8');// 或者$connect = mysqli_connect('127.0.0.1', 'root', 'root', 'test', 8889);$connect->set_charset('utf8'); # 都可以这么使用 3. 执行sql语句 通过mysqli_query()进行执行SELECT, SHOW,DESCRIBE或 EXPLAIN,失败时返回false $sql = "SHOW TABLES"; $res = $connect->query($sql); # 或者 mysqli_query($connect, $sql); 打印一下他返回了什么 var_dump($res);object(mysqli_result)[2] public 'current_field' => int 0 public 'field_count' => int 1 public 'lengths' => null public 'num_rows' => int 2 # 返回了几条数据 public 'type' => int 0 4. 获取结果 通过mysqli_query()执行的sql语句之后如何获取结果呢?可以通过mysqli_fetch_array()、mysqli_fetch_assoc()、mysqli_fetch_all()、mysqli_fetch_row()等进行获取结果 当需要获取一条数据的时候可以使用mysqli_fetch_row() mysqli_fetch_array() 该函数的第一个参数是通过mysqli_query()返回的对象 第二个参数是获取结果的类型: ​ MYSQLI_ASSOC 关联数组 同mysqli_fetch_assoc()函数 ​ MYSQLI_NUM 数字数组 ​ MYSQLI_BOTH默认。同时产生关联和数字数组

    02

    【DB笔试面试553】在Oracle中,什么是不可见索引?

    索引维护是DBA的一项重要工作。当一个系统运行很长一段时间,经过需求变更、结构设计变化后,系统中就可能会存在一些不再被使用的索引,或者使用效率很低的索引。这些索引的存在,不仅占用系统空间,而且会降低事务效率,增加系统的负载。因此,需要找出那些无用或低效的索引,并删除它们(找出无用索引可以通过索引监控的方法)。但是,直接删除索引还是存在一定风险的。例如,某些索引可能只是在一些周期的作业中被使用到,而如果监控周期没有覆盖到这些作业的触发点,那么就会认为索引是无用的,从而将其删除。当作业启动后,可能就会对系统性能造成冲击。这时,可能就会手忙脚乱地去找回索引定义语句、重建索引。在Oracle 11g里,Oracle提供了一个新的特性来降低直接删除索引或者禁用索引的风险,那就是不可见索引(Invisible Indexes)。

    02
    领券