返回顶部
首页 > 资讯 > 数据库 >MySQL中mysql_store_result() 和 mysql_use_result() 函数的区别是什么
  • 245
分享到

MySQL中mysql_store_result() 和 mysql_use_result() 函数的区别是什么

2024-04-02 19:04:59 245人浏览 独家记忆
摘要

这篇文章给大家介绍Mysql中mysql_store_result() 和 mysql_use_result() 函数的区别是什么,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。函数my

这篇文章给大家介绍Mysqlmysql_store_result() 和 mysql_use_result() 函数的区别是什么,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。

函数mysql_store_result()与mysql_use_result()类似,它们都有连接处理程序参数,并返回结果集。但实际上两者间的区别还是很大的。两个函数之间首要的区别在于从服务器上检索结果集的行。

当调用时,mysql_store_result()立即检索所有的行,而mysql_use_result()启动查询,但实际上并未获取任何行,mysql_store_result()假设随后会调用mysql_fetch_row()检索记录。这些行检索的不同方法引起两者在其他方面的不同。本文加以比较,以便了解如何选择最适合应用程序的方法。

当mysql_store_result()从服务器上检索结果集时,就提取了行,并为之分配内存,存储到客户机中,随后调用mysql_fetch_row()就再也不会返回错误,因为它仅仅是把行脱离了已经保留结果集的数据结构

mysql_fetch_row()返回NULL始终表示已经到达结果集的末端。相反,mysql_use_result()本身不检索任何行,而只是启动一个逐行的检索,就是说必须对每行调用mysql_fetch_row()来自己完成。既然如此,虽然正常情况下,mysql_fetch_row()返回NULL仍然表示此时已到达结果集的末端,但也可能表示在与服务器通信时发生错误。可通过调用mysql_errno()和mysql_error()将两者区分开来。

与mysql_use_result()相比,mysql_store_result()有着较高的内存和处理需求,因为是在客户机上维护整个结果集,所以内存分配和创建数据结构的耗费是非常巨大的,要冒着溢出内存的危险来检索大型结果集,如果想一次检索多个行,可用mysql_use_result()  。mysql_use_result()有着较低的内存需求,因为只需给每次处理的单行分配足够的空间。这样速度就较快,因为不必为结果集建立复杂的数据结构。另一方面,mysql_use_result()把较大的负载加到了服务器上,它必须保留结果集中的行,直到客户机看起来适合检索所有的行。这就使某些类型的客户机程序不适用mysql_use_result():在用户的请求下提前逐行进行的交互式客户机程序(不必仅仅因为用户需要喝杯咖啡而让服务器等待发送下一行)。

在行检索之间做了许多处理的客户机程序。在所有这些情况下,客户机程序都不能很快检索结果集的所有行,它限制了服务器,并对其他客户机程序产生负面的影响,因为检索数据的表在查询过程中是读定的。要更新表的客户机或要插入行的任何客户机程序都被阻塞。

在使用mysql_query()进行一个查询后,一般要用这两个函数之一来把结果存到一个MYSQL_RES *变量中。

两者的主要区别是,mysql_use_result()的结果必须“一次性用完”,也就是说用它得到一个result后,必须反复用mysql_fetch_row()读取其结果直至该函数返回null为止,否则如果你再次进行mysql查询,就会得到“Commands out of sync; you can’t run this command now”的错误。而mysql_store_result()得到的result是存下来的,你无需把全部行结果读完,就可以进行另外的查询。例如你进行一个查询,得到一系列记录,再根据这些结果,用一个循环再进行数据库查询,就只能用mysql_store_result()。

关于MySQL中mysql_store_result() 和 mysql_use_result() 函数的区别是什么就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

您可能感兴趣的文档:

--结束END--

本文标题: MySQL中mysql_store_result() 和 mysql_use_result() 函数的区别是什么

本文链接: https://lsjlt.com/news/57194.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • MySQL中mysql_store_result() 和 mysql_use_result() 函数的区别是什么
    这篇文章给大家介绍MySQL中mysql_store_result() 和 mysql_use_result() 函数的区别是什么,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。函数my...
    99+
    2024-04-02
  • Mysql中存储过程和函数的区别是什么
    这篇文章主要介绍了Mysql中存储过程和函数的区别是什么,具有一定借鉴价值,需要的朋友可以参考下。希望大家阅读完这篇文章后大有收获。下面让小编带着大家一起了解一下。数据库设计三范式:第一范式:数据库表的每一...
    99+
    2024-04-02
  • MYSQL中#和$的区别是什么
    小编给大家分享一下MYSQL中#和$的区别是什么,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!他们之间的区别用最直接的话来说就是...
    99+
    2024-04-02
  • MySQL中“:=”和“=”的区别是什么
    小编给大家分享一下MySQL中“:=”和“=”的区别是什么,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!=只有在set和upda...
    99+
    2024-04-02
  • java中函数和方法的区别是什么?
    java中函数和方法的区别是什么?面向对象的语言叫方法面向过程的语言叫函数在java中没有函数这么一说,只有方法一说。实际上方法就是函数,函数就是方法,只是在不同的语言不同的称呼而已。【推荐教程:Java视频教程】一句话告诉你如何区分函数与...
    99+
    2022-02-08
    java入门 java 函数 方法
  • python中map和filter函数的区别是什么
    python中map和filter函数的区别是什么?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。python的五大特点是什么python的五大特点:1.简单易学,开发程序时...
    99+
    2023-06-14
  • 函数fmt.Print和fmt.Println的区别是什么?
    ...
    99+
    2024-04-02
  • c++虚函数和纯函数的区别是什么
    C++中的虚函数和纯虚函数都是用来实现多态性的机制,但它们有一些不同之处。 虚函数是在基类中声明的,可以在派生类中进行重写,它允许在...
    99+
    2023-10-26
    c++
  • C#中构造函数和析构函数的区别是什么
    这篇文章将为大家详细讲解有关C#中构造函数和析构函数的区别是什么,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。C#构造函数和析构函数在你可以访问一个类的方法、属性或任何其它东西之前, ***...
    99+
    2023-06-18
  • MySQL INSTR() 和 FIND_IN_SET() 函数有什么区别?
    众所周知,这两个函数都用于根据它们提供的参数搜索字符串,但它们之间存在一些显着差异,如下所示FIND_IN_SET()函数使用的字符串列表本身就是一个包含以逗号分隔的子字符串的字符串。而 INSTR() 函数包含一个字符串,它将从中查找子字...
    99+
    2023-10-22
  • MySQL LENGTH() 和 CHAR_LENGTH() 函数有什么区别?
    这两个函数都是字符串函数,并返回字符串中存在的字符数。但它们的不同之处在于 CHAR_LENGTH() 函数以“字符”为单位测量字符串长度,而 LENGTH() 函数以“字节”为单位测量字符串长度。换句话说,我们可以说 CHAR_LENGT...
    99+
    2023-10-22
  • MySQL INSTR() 和 FIND_IN_SET() 函数有什么区别
    MySQL INSTR() 函数用于在字符串中查找子字符串,并返回子字符串在原字符串中的位置。它的语法如下:INSTR(str, s...
    99+
    2023-10-20
    MySQL
  • mysql中dumpfile与outfile函数的区别是什么
    这篇文章将为大家详细讲解有关mysql中dumpfile与outfile函数的区别是什么,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。&...
    99+
    2024-04-02
  • mysql中in和exists的区别是什么
    这篇文章主要介绍mysql中in和exists的区别是什么,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!exists和in的区别有:in是把外表和内表做hash连接,先查询内表;ex...
    99+
    2024-04-02
  • MySQL 中 InnoDB 和 MyISAM 的区别是什么
    今天就跟大家聊聊有关MySQL 中 InnoDB 和 MyISAM 的区别是什么,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。  InnoDB 和 ...
    99+
    2024-04-02
  • mysql中int和bigint的区别是什么
    这篇文章将为大家详细讲解有关mysql中int和bigint的区别是什么,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。  1 bytes = 8 bit ,...
    99+
    2024-04-02
  • Mysql中 InnoDB和MyISAM的区别是什么
    本篇文章给大家分享的是有关Mysql中 InnoDB和MyISAM的区别是什么,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。 Inn...
    99+
    2024-04-02
  • mysql中exists 和in的区别是什么
    今天就跟大家聊聊有关mysql中exists 和in的区别是什么,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。  MySQL中in和exists的性...
    99+
    2024-04-02
  • mysql中date和datetime的区别是什么
    在MySQL中,DATE和DATETIME都是用于存储日期和时间信息的数据类型,但它们之间有一些区别: DATE类型存储日期信息,...
    99+
    2024-04-09
    mysql
  • JS构造函数中this和return的区别是什么
    本篇文章给大家分享的是有关JS构造函数中this和return的区别是什么,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。先看一段代码,func...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作