當前位置: 首頁>>代碼示例>>PHP>>正文


PHP Kwf_Model_Abstract::export方法代碼示例

本文整理匯總了PHP中Kwf_Model_Abstract::export方法的典型用法代碼示例。如果您正苦於以下問題:PHP Kwf_Model_Abstract::export方法的具體用法?PHP Kwf_Model_Abstract::export怎麽用?PHP Kwf_Model_Abstract::export使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在Kwf_Model_Abstract的用法示例。


在下文中一共展示了Kwf_Model_Abstract::export方法的1個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: export

 public function export($format, $select = array(), $options = array())
 {
     if ($format == self::FORMAT_SQL) {
         $wherePart = '';
         if ($select) {
             if (!is_object($select)) {
                 if (is_string($select)) {
                     $select = array($select);
                 }
                 $select = $this->select($select);
             }
             $dbSelect = $this->_getDbSelect($select);
             $whereParts = $dbSelect->getPart(Zend_Db_Select::WHERE);
             $wherePart = implode(' ', $whereParts);
             // check if a row is exported and quit, if none
             $dbSelect->limit(1);
             $hasRows = $dbSelect->query()->fetchAll();
             if (!count($hasRows)) {
                 return '';
             }
         }
         if ($wherePart) {
             $wherePart = '--where="' . $wherePart . '" ';
         }
         $systemData = $this->_getSystemData();
         $filename = tempnam('/tmp', 'modelimport');
         $cmd = "{$systemData['mysqlDir']}mysqldump --add-drop-table=false ";
         $cmd .= "--skip-add-locks --complete-insert ";
         $cmd .= "--no-create-info=true " . $wherePart . "{$systemData['mysqlOptions']} {$systemData['tableName']} | gzip -c > {$filename}";
         exec($cmd, $output, $ret);
         if ($ret != 0) {
             throw new Kwf_Exception("SQL export failed");
         }
         $ret = file_get_contents($filename);
         unlink($filename);
         return $ret;
     } else {
         if ($format == self::FORMAT_CSV) {
             if (!is_object($select)) {
                 if (is_string($select)) {
                     $select = array($select);
                 }
                 $select = $this->select($select);
             }
             $tmpExportFolder = realpath('temp') . '/modelcsvex' . uniqid();
             $filename = $tmpExportFolder . '/csvexport';
             $dbSelect = $this->_createDbSelectWithColumns($select, $options);
             $sqlString = $dbSelect->assembleIntoOutfile($filename);
             $dbSelect->limit(1);
             $fieldResult = $dbSelect->query()->fetchAll();
             $columnsCsv = '';
             if (count($fieldResult)) {
                 mkdir($tmpExportFolder, 0777);
                 $columns = array_keys($fieldResult[0]);
                 $columnsCsv = '"' . implode('","', $columns) . '"';
                 $this->executeSql($sqlString);
                 $cmd = "{ echo '{$columnsCsv}'; cat {$filename}; } | gzip -c > {$filename}.gz";
                 exec($cmd, $output, $ret);
                 if ($ret != 0) {
                     throw new Kwf_Exception("CSV-SQL export failed");
                 }
                 if (!file_exists($filename . '.gz')) {
                     throw new Kwf_Exception("Error exporting csv from model - target file has not been created");
                 }
                 unlink($filename);
                 $ret = file_get_contents($filename . '.gz');
                 unlink($filename . '.gz');
                 rmdir($tmpExportFolder);
                 return $ret;
             } else {
                 return '';
             }
         } else {
             if ($format == self::FORMAT_ARRAY) {
                 if (!is_object($select)) {
                     if (is_string($select)) {
                         $select = array($select);
                     }
                     $select = $this->select($select);
                 }
                 if ($select->hasPart(Kwf_Model_Select::UNION)) {
                     $select = clone $select;
                     $unions = $select->getPart(Kwf_Model_Select::UNION);
                     $select->unsetPart(Kwf_Model_Select::UNION);
                     $selects = array($select);
                     $selects = array_merge($selects, $unions);
                     $ret = array();
                     while ($selects) {
                         //split up into blocks of 150, mysql doesn't take more
                         $curSelects = array_splice($selects, 0, min(150, count($selects)));
                         $unions = array();
                         foreach ($curSelects as $s) {
                             $unions[] = $this->_createDbSelectWithColumns($s, $options);
                         }
                         $ret = array_merge($ret, $this->getAdapter()->query(implode(" UNION ", $unions))->fetchAll());
                     }
                     return $ret;
                 } else {
                     $dbSelect = $this->_createDbSelectWithColumns($select, $options);
                     if (!$dbSelect) {
//.........這裏部分代碼省略.........
開發者ID:nsams,項目名稱:koala-framework,代碼行數:101,代碼來源:Db.php


注:本文中的Kwf_Model_Abstract::export方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。