pbootcms网站模板|日韩1区2区|织梦模板||网站源码|日韩1区2区|jquery建站特效-html5模板网

<legend id='M5Hgr'><style id='M5Hgr'><dir id='M5Hgr'><q id='M5Hgr'></q></dir></style></legend>
<i id='M5Hgr'><tr id='M5Hgr'><dt id='M5Hgr'><q id='M5Hgr'><span id='M5Hgr'><b id='M5Hgr'><form id='M5Hgr'><ins id='M5Hgr'></ins><ul id='M5Hgr'></ul><sub id='M5Hgr'></sub></form><legend id='M5Hgr'></legend><bdo id='M5Hgr'><pre id='M5Hgr'><center id='M5Hgr'></center></pre></bdo></b><th id='M5Hgr'></th></span></q></dt></tr></i><div class="1xtrphj" id='M5Hgr'><tfoot id='M5Hgr'></tfoot><dl id='M5Hgr'><fieldset id='M5Hgr'></fieldset></dl></div>
      <bdo id='M5Hgr'></bdo><ul id='M5Hgr'></ul>

  • <tfoot id='M5Hgr'></tfoot>

        <small id='M5Hgr'></small><noframes id='M5Hgr'>

        大結果集的 PDO/MySQL 內存消耗

        PDO/MySQL memory consumption with large result set(大結果集的 PDO/MySQL 內存消耗)

      1. <i id='k7x5l'><tr id='k7x5l'><dt id='k7x5l'><q id='k7x5l'><span id='k7x5l'><b id='k7x5l'><form id='k7x5l'><ins id='k7x5l'></ins><ul id='k7x5l'></ul><sub id='k7x5l'></sub></form><legend id='k7x5l'></legend><bdo id='k7x5l'><pre id='k7x5l'><center id='k7x5l'></center></pre></bdo></b><th id='k7x5l'></th></span></q></dt></tr></i><div class="rv5t77x" id='k7x5l'><tfoot id='k7x5l'></tfoot><dl id='k7x5l'><fieldset id='k7x5l'></fieldset></dl></div>

        <small id='k7x5l'></small><noframes id='k7x5l'>

      2. <tfoot id='k7x5l'></tfoot>
      3. <legend id='k7x5l'><style id='k7x5l'><dir id='k7x5l'><q id='k7x5l'></q></dir></style></legend>
            <tbody id='k7x5l'></tbody>

              • <bdo id='k7x5l'></bdo><ul id='k7x5l'></ul>
                • 本文介紹了大結果集的 PDO/MySQL 內存消耗的處理方法,對大家解決問題具有一定的參考價值,需要的朋友們下面隨著小編來一起學習吧!

                  問題描述

                  我在處理從大約 30,000 行的表中進行選擇時遇到了奇怪的時間.

                  I'm having a strange time dealing with selecting from a table with about 30,000 rows.

                  似乎我的腳本使用了大量的內存來實現一個簡單的、僅向前遍歷查詢結果的內容.

                  It seems my script is using an outrageous amount of memory for what is a simple, forward only walk over a query result.

                  請注意,這個例子是一個有點人為的、絕對最低限度的例子,它與真實代碼幾乎沒有相似之處,不能用簡單的數據庫聚合來代替.旨在說明不需要在每次迭代中保留每一行的觀點.

                  Please note that this example is a somewhat contrived, absolute bare minimum example which bears very little resemblance to the real code and it cannot be replaced with a simple database aggregation. It is intended to illustrate the point that each row does not need to be retained on each iteration.

                  <?php
                  $pdo = new PDO('mysql:host=127.0.0.1', 'foo', 'bar', array(
                      PDO::ATTR_ERRMODE=>PDO::ERRMODE_EXCEPTION,
                  ));
                  $stmt = $pdo->prepare('SELECT * FROM round');
                  $stmt->execute();
                  
                  function do_stuff($row) {}
                  
                  $c = 0;
                  while ($row = $stmt->fetch()) {
                      // do something with the object that doesn't involve keeping 
                      // it around and can't be done in SQL
                      do_stuff($row);
                      $row = null;
                      ++$c;
                  }
                  
                  var_dump($c);
                  var_dump(memory_get_usage());
                  var_dump(memory_get_peak_usage());
                  

                  輸出:

                  int(39508)
                  int(43005064)
                  int(43018120)
                  

                  我不明白為什么在任何時候幾乎不需要保存任何數據的情況下使用 40 兆內存.我已經計算出通過將SELECT *"替換為SELECT home, away",我可以將內存減少大約 6 倍,但是我認為即使這種用法也非常高,而且表只會變得更大.

                  I don't understand why 40 meg of memory is used when hardly any data needs to be held at any one time. I have already worked out I can reduce the memory by a factor of about 6 by replacing "SELECT *" with "SELECT home, away", however I consider even this usage to be insanely high and the table is only going to get bigger.

                  是否有我遺漏的設置,或者 PDO 中是??否存在一些我應該注意的限制?如果 mysqli 不支持,我很高興擺脫 PDO 以支持 mysqli,所以如果這是我唯一的選擇,我將如何使用 mysqli 執行此操作?

                  Is there a setting I'm missing, or is there some limitation in PDO that I should be aware of? I'm happy to get rid of PDO in favour of mysqli if it can not support this, so if that's my only option, how would I perform this using mysqli instead?

                  推薦答案

                  創建連接后,需要設置PDO::MYSQL_ATTR_USE_BUFFERED_QUERY 為假:

                  After creating the connection, you need to set PDO::MYSQL_ATTR_USE_BUFFERED_QUERY to false:

                  <?php
                  $pdo = new PDO('mysql:host=127.0.0.1', 'foo', 'bar', array(
                      PDO::ATTR_ERRMODE=>PDO::ERRMODE_EXCEPTION,
                  ));
                  $pdo->setAttribute(PDO::MYSQL_ATTR_USE_BUFFERED_QUERY, false);
                  
                  // snip
                  
                  var_dump(memory_get_usage());
                  var_dump(memory_get_peak_usage());
                  

                  輸出:

                  int(39508)
                  int(653920)
                  int(668136)
                  

                  無論結果大小如何,內存使用量幾乎保持不變.

                  Regardless of the result size, the memory usage remains pretty much static.

                  這篇關于大結果集的 PDO/MySQL 內存消耗的文章就介紹到這了,希望我們推薦的答案對大家有所幫助,也希望大家多多支持html5模板網!

                  【網站聲明】本站部分內容來源于互聯網,旨在幫助大家更快的解決問題,如果有圖片或者內容侵犯了您的權益,請聯系我們刪除處理,感謝您的支持!

                  相關文檔推薦

                  Deadlock exception code for PHP, MySQL PDOException?(PHP、MySQL PDOException 的死鎖異常代碼?)
                  PHP PDO MySQL scrollable cursor doesn#39;t work(PHP PDO MySQL 可滾動游標不起作用)
                  PHP PDO ODBC connection(PHP PDO ODBC 連接)
                  Using PDO::FETCH_CLASS with Magic Methods(使用 PDO::FETCH_CLASS 和魔術方法)
                  php pdo get only one value from mysql; value that equals to variable(php pdo 只從 mysql 獲取一個值;等于變量的值)
                  MSSQL PDO could not find driver(MSSQL PDO 找不到驅動程序)

                  <small id='v68f6'></small><noframes id='v68f6'>

                    • <tfoot id='v68f6'></tfoot>
                      • <i id='v68f6'><tr id='v68f6'><dt id='v68f6'><q id='v68f6'><span id='v68f6'><b id='v68f6'><form id='v68f6'><ins id='v68f6'></ins><ul id='v68f6'></ul><sub id='v68f6'></sub></form><legend id='v68f6'></legend><bdo id='v68f6'><pre id='v68f6'><center id='v68f6'></center></pre></bdo></b><th id='v68f6'></th></span></q></dt></tr></i><div class="pzjn7zz" id='v68f6'><tfoot id='v68f6'></tfoot><dl id='v68f6'><fieldset id='v68f6'></fieldset></dl></div>
                            <tbody id='v68f6'></tbody>
                            <bdo id='v68f6'></bdo><ul id='v68f6'></ul>
                            <legend id='v68f6'><style id='v68f6'><dir id='v68f6'><q id='v68f6'></q></dir></style></legend>
                            主站蜘蛛池模板: 十字轴_十字轴万向节_十字轴总成-南京万传机械有限公司 | 高压贴片电容|贴片安规电容|三端滤波器|风华电容代理南京南山 | 土壤检测仪器_行星式球磨仪_土壤团粒分析仪厂家_山东莱恩德智能科技有限公司 | 好杂志网-首页 | 预制舱-电力集装箱预制舱-模块化预制舱生产厂家-腾达电器设备 | 震动筛选机|震动分筛机|筛粉机|振筛机|振荡筛-振动筛分设备专业生产厂家高服机械 | ETFE膜结构_PTFE膜结构_空间钢结构_膜结构_张拉膜_浙江萬豪空间结构集团有限公司 | 氮化镓芯片-碳化硅二极管 - 华燊泰半导体 | 泰州物流公司_泰州货运公司_泰州物流专线-东鑫物流公司 | 北京西风东韵品牌与包装设计公司,创造视觉销售力! | 加气混凝土砌块设备,轻质砖设备,蒸养砖设备,新型墙体设备-河南省杜甫机械制造有限公司 | 转向助力泵/水泵/发电机皮带轮生产厂家-锦州华一精工有限公司 | 房车价格_依维柯/大通/东风御风/福特全顺/江铃图片_云梯搬家车厂家-程力专用汽车股份有限公司 | 中空玻璃生产线,玻璃加工设备,全自动封胶线,铝条折弯机,双组份打胶机,丁基胶/卧式/立式全自动涂布机,玻璃设备-山东昌盛数控设备有限公司 | 上海单片机培训|重庆曙海培训分支机构—CortexM3+uC/OS培训班,北京linux培训,Windows驱动开发培训|上海IC版图设计,西安linux培训,北京汽车电子EMC培训,ARM培训,MTK培训,Android培训 | 鼓风干燥箱_真空烘箱_高温干燥箱_恒温培养箱-上海笃特科学仪器 | 定制防伪标签_防伪标签印刷_防伪标签厂家-510品保防伪网 | 青岛侦探_青岛侦探事务所_青岛劝退小三_青岛婚外情取证-青岛王军侦探事务所 | 汽车整车综合环境舱_军标砂尘_盐雾试验室试验箱-无锡苏南试验设备有限公司 | 智能气瓶柜(大型气瓶储存柜)百科 | 海外仓系统|国际货代系统|退货换标系统|WMS仓储系统|海豚云 | 直读光谱仪,光谱分析仪,手持式光谱仪,碳硫分析仪,创想仪器官网 | 膏剂灌装旋盖机-眼药水灌装生产线-西林瓶粉剂分装机-南通博琅机械科技 | 展厅设计公司,展厅公司,展厅设计,展厅施工,展厅装修,企业展厅,展馆设计公司-深圳广州展厅设计公司 | 利浦顿蒸汽发生器厂家-电蒸汽发生器/燃气蒸汽发生器_湖北利浦顿热能科技有限公司官网 | 焊接烟尘净化器__焊烟除尘设备_打磨工作台_喷漆废气治理设备 -催化燃烧设备 _天津路博蓝天环保科技有限公司 | 企典软件一站式企业管理平台,可私有、本地化部署!在线CRM客户关系管理系统|移动办公OA管理系统|HR人事管理系统|人力 | 中控室大屏幕-上海亿基自动化控制系统工程有限公司 | 细胞染色-流式双标-试剂盒免费代做-上海研谨生物科技有限公司 | 安徽华耐泵阀有限公司-官方网站 安德建奇火花机-阿奇夏米尔慢走丝|高维|发那科-北京杰森柏汇 | SPC工作站-连杆综合检具-表盘气动量仪-内孔缺陷检测仪-杭州朗多检测仪器有限公司 | 废气处理设备-工业除尘器-RTO-RCO-蓄热式焚烧炉厂家-江苏天达环保设备有限公司 | 微量水分测定仪_厂家_卡尔费休微量水分测定仪-淄博库仑 | 香蕉筛|直线|等厚|弧形|振动筛|香蕉筛厂家-洛阳隆中重工 | 琉璃瓦-琉璃瓦厂家-安徽盛阳新型建材科技有限公司 | 智能化的检漏仪_气密性测试仪_流量测试仪_流阻阻力测试仪_呼吸管快速检漏仪_连接器防水测试仪_车载镜头测试仪_奥图自动化科技 | 深圳快餐店设计-餐饮设计公司-餐饮空间品牌全案设计-深圳市勤蜂装饰工程 | 贴片电容-贴片电阻-二三极管-国巨|三星|风华贴片电容代理商-深圳伟哲电子 | 上海物流公司,上海货运公司,上海物流专线-优骐物流公司 | 捷码低代码平台 - 3D数字孪生_大数据可视化开发平台「免费体验」 | 高空重型升降平台_高空液压举升平台_高空作业平台_移动式升降机-河南华鹰机械设备有限公司 |