免费观看又色又爽又黄的小说免费_美女福利视频国产片_亚洲欧美精品_美国一级大黄大色毛片

php大量數據 php data

在PHP中怎么解決大量數據處理的問題

mysql_query函數查詢的方式是查詢出全部結果后緩存到內存中,這樣就會出現超內存的現象,使用另外一個函數mysql_unbuffered_query可以解決這個問題,mysql_unbuffered_query不會緩存結果集,而是查詢出來數據后立馬對結果集進行操作,也就是便查詢邊返回,這樣就不會出現超出內存的現象,但是使用mysql_unbuffered_query的是時候不能使用 mysql_num_rows() 和 mysql_data_seek()。并且向 MySQL 發送一條新的 SQL 查詢之前,必須提取掉所有未緩存的 SQL 查詢所產生的結果行。例如:

創新互聯公司專注為客戶提供全方位的互聯網綜合服務,包含不限于網站設計、成都網站設計、金臺網絡推廣、小程序定制開發、金臺網絡營銷、金臺企業策劃、金臺品牌公關、搜索引擎seo、人物專訪、企業宣傳片、企業代運營等,從售前售中售后,我們都將竭誠為您服務,您的肯定,是我們最大的嘉獎;創新互聯公司為所有大學生創業者提供金臺建站搭建服務,24小時服務熱線:18982081108,官方網址:m.newbst.com

使用緩存結果集的代碼:

function selecttest()

{

try {

$pdo = new PDO("mysql:host=localhost;dbname=test", 'root', '123456');

// 不使用緩存結果集方式

// $pdo-setAttribute(PDO::MYSQL_ATTR_USE_BUFFERED_QUERY, false);

$sth = $pdo-prepare('select * from test');

$sth-execute();

echo '最初占用內存大?。? . memory_get_usage() . "\n";

$i = 0;

while ($result = $sth-fetch(PDO::FETCH_ASSOC)) {

$i += 1;

if ($i 10) {

break;

}

sleep(1);

print_r($result);

echo '占用內存大?。? . memory_get_usage() . "\n";

}

} catch (Exception $e) {

echo $e-getMessage();

}

}

執行時將會報超出內存的錯誤:

Fatal error: Allowed memory size of 134217728 bytes exhausted (tried to allocate 204800000 bytes) in E:\ProgramDevelopment\RuntimeEnvironment\xampp\htdocs\test\test.php on line 56

Call Stack:

0.0005 135392 1. {main}() E:\ProgramDevelopment\RuntimeEnvironment\xampp\htdocs\test\test.php:0

0.0005 135568 2. test-selecttest() E:\ProgramDevelopment\RuntimeEnvironment\xampp\htdocs\test\test.php:85

0.0050 142528 3. PDOStatement-execute() E:\ProgramDevelopment\RuntimeEnvironment\xampp\htdocs\test\test.php:56

將上面代碼中的$pdo-setAttribute(PDO::MYSQL_ATTR_USE_BUFFERED_QUERY, false);一行的注釋去掉后將不在緩存結果集,這時運行該函數的結果如下:

最初占用內存大?。?44808

Array

(

[id] = 1

[a] = v

[b] = w

[c] = i

)

占用內存大?。?45544

Array

(

[id] = 2

[a] = b

[b] = l

[c] = q

)

占用內存大?。?45544

Array

(

[id] = 3

[a] = m

[b] = p

[c] = h

)

占用內存大小:145536

Array

(

[id] = 4

[a] = j

[b] = i

[c] = b

)

占用內存大?。?45536

可以看到,這時返回一條數據內存占用非常的小,也就700多字節,這樣就不會出現超出內存的錯誤了。

php怎么導出大量數據的Excel

php導出大量數據Excel的具體操作步驟如下:

1、使用phpstudy搭建一個測試平臺,直接訪問數據庫。

2、下載的phpcms安裝包拷貝到IIS目錄,開通訪問,即可搭建成功。

3、登錄網站后臺,系統權限,文件目錄以及數據庫等功能,進行管理。

4、在phpcms后臺,擴展,數據庫工具,數據庫導出,程序池選擇phpcmsv9,開始備份數據。

5、打開IIS網站目錄,在D:\wwwroot\kmxy\wwwroot\caches\bakup\default文件夾,查看導出的數據庫文件。

6、登錄phpmyadmin,選擇數據庫導出,選擇Excel格式,即可導出。

如何解決PHP查詢大量數據內存耗盡的問題

這個問題在PHP的官方網站上叫緩沖查詢和非緩沖查詢(Buffered and Unbuffered queries)。PHP的查詢缺省模式是緩沖模式。也就是說,查詢數據結果會一次全部提取到內存里供PHP程序處理。這樣給了PHP程序額外的功能,比如說,計算行數,將指針指向某一行等。更重要的是程序可以對數據集反復進行二次查詢和過濾等操作。但這種緩沖查詢模式的缺陷就是消耗內存,也就是用空間換速度。

相對的,另外一種PHP查詢模式是非緩沖查詢,數據庫服務器會一條一條的返回數據,而不是一次全部返回,這樣的結果就是PHP程序消耗較少的內存,但卻增加了數據庫服務器的壓力,因為數據庫會一直等待PHP來取數據,一直到數據全部取完。

很顯然,緩沖查詢模式適用于小數據量查詢,而非緩沖查詢適應于大數據量查詢。

網頁標題:php大量數據 php data
網址分享:http://m.newbst.com/article12/ddshsgc.html

成都網站建設公司_創新互聯,為您提供ChatGPT外貿網站建設、搜索引擎優化定制網站、、網站維護

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

成都定制網站建設