On 23 Oct 2011, at 06:52, AmirBehzad Eslami wrote:
> Dear list,
> As you already know, there are different ways to retrieve a record-set
> from a database. For example, here's the classic way to perform this in PHP:
>
> while ($row = mysql_fetch_assoc($db)) {
> // my row is available here
> }
>
> Speacking about PHP internals, what exactly happens here?
> 1) The PHP asks the Database-Layer to give a record in each while pass?
> I mean the record-set is not available in PHP's memory, but in MySQL's Mem.
>
> 2) Or the database-layer has gave the whole result-set to PHP, and we're
> just fetching a single row from PHP's memory?
It depends what function was used to do the query...
mysql_query will fetch all result rows from MySQL into a buffer.
mysql_unbuffered_query does not.
Read the documentation for mysql_unbuffered_query carefully before you start
using it: http://php.net/mysql_unbuffered_query
> 3) Finally, what is the efficient way to retrieve thousands or records which
> need to be processed at once? Using LIMIT?
Yes, use mysql_buffered_query, or mysql_query with limit to work through the
results in a paginated fashion.
-Stuart
--
Stuart Dallas
3ft9 Ltd
http://3ft9.com/
--
PHP General Mailing List (http://www.php.net/)
To unsubscribe, visit: http://www.php.net/unsub.php