mysql_query($sql)到底返回boolen值还是resourceid?该怎么解决
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了mysql_query($sql)到底返回boolen值还是resourceid?该怎么解决,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2300字,纯文字阅读大概需要4分钟。
内容图文
![mysql_query($sql)到底返回boolen值还是resourceid?该怎么解决](/upload/InfoBanner/zyjiaocheng/212/6768b02bce4a4cdb97dca2f13ea1fc5e.jpg)
- PHP code
如果用sql,输出为ok ,the user existResource id #4
如果用sql2, 输出为the user not exist
声明一下,id = 222 的数据在数据库中是不存在的,为什么会有这样的结果?
用sql查询,返回的是资源ID,用sql2查询,返回的是布尔值,为什么?
------解决方案--------------------
查询成功就返回资源id,这与结果有多少没有关系
获取查询结果的行数用 mysql_num_rows
------解决方案--------------------
$result=mysql_query($sql);
if (!$mysql_num_rows($result)){
echo( "the user not exist" );
}else{
echo( "ok ,login sucsuss);
}
------解决方案--------------------
- PHP code
mysql_query ― 发送一条 MySQL 查询 说明 resource mysql_query ( string $query [, resource $link_identifier ] ) mysql_query() 向与指定的连接标识符关联的服务器中的当前活动数据库发送一条查询。如果没有指定 link_identifier,则使用上一个打开的连接。如果没有打开的连接,本函数会尝试无参数调用 mysql_connect() 函数来建立一个连接并使用之。查询结果会被缓存。 Note: 查询字符串不应以分号结束。 mysql_query() 仅对 SELECT,SHOW,EXPLAIN 或 DESCRIBE 语句返回一个资源标识符,如果查询执行不正确则返回 FALSE。对于其它类型的 SQL 语句,mysql_query() 在执行成功时返回 TRUE,出错时返回 FALSE。非 FALSE 的返回值意味着查询是合法的并能够被服务器执行。这并不说明任何有关影响到的或返回的行数。 很有可能一条查询执行成功了但并未影响到或并未返回任何行。 以下查询语法上有错,因此 mysql_query() 失败并返回 FALSE: Example #1 mysql_query() 例子 <php $result = mysql_query("SELECT * WHERE 1=1") or die("Invalid query: " . mysql_error()); ?> 以下查询当 my_col 并不是表 my_tbl 中的列时语义上有错,因此 mysql_query() 失败并返回 FALSE: Example #2 mysql_query() 如果没有权限访问查询语句中引用的表时,mysql_query() 也会返回 FALSE。 假定查询成功,可以调用 mysql_num_rows() 来查看对应于 SELECT 语句返回了多少行,或者调用 mysql_affected_rows() 来查看对应于 DELETE,INSERT,REPLACE 或 UPDATE 语句影响到了多少行。 仅对 SELECT,SHOW,DESCRIBE 或 EXPLAIN 语句 mysql_query() 才会返回一个新的结果标识符,可以将其传递给 mysql_fetch_array() 和其它处理结果表的函数。处理完结果集后可以通过调用 mysql_free_result() 来释放与之关联的资源,尽管脚本执行完毕后会自动释放内存。 参见 mysql_num_rows(),mysql_affected_rows(),mysql_unbuffered_query(),mysql_free_result(),mysql_fetch_array(),mysql_fetch_row(),mysql_fetch_assoc(),mysql_result(),mysql_select_db() 和 mysql_connect()。
内容总结
以上是互联网集市为您收集整理的mysql_query($sql)到底返回boolen值还是resourceid?该怎么解决全部内容,希望文章能够帮你解决mysql_query($sql)到底返回boolen值还是resourceid?该怎么解决所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。