⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 trackerqueriesdatabasestore.php

📁 SugarCRM5.1 开源PHP客户关系管理系统
💻 PHP
字号:
<?php
if(!defined('sugarEntry') || !sugarEntry) die('Not A Valid Entry Point');
/*********************************************************************************
 * SugarCRM is a customer relationship management program developed by * SugarCRM, Inc. Copyright (C) 2004 - 2007 SugarCRM Inc. *  * This program is free software; you can redistribute it and/or modify it under * the terms of the GNU General Public License version 3 as published by the * Free Software Foundation with the addition of the following permission added * to Section 15 as permitted in Section 7(a): FOR ANY PART OF THE COVERED WORK * IN WHICH THE COPYRIGHT IS OWNED BY SUGARCRM, SUGARCRM DISCLAIMS THE WARRANTY * OF NON INFRINGEMENT OF THIRD PARTY RIGHTS. *  * This program is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS * FOR A PARTICULAR PURPOSE.  See the GNU General Public License for more * details. *  * You should have received a copy of the GNU General Public License along with * this program; if not, see http://www.gnu.org/licenses or write to the Free * Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA * 02110-1301 USA. *  * You can contact SugarCRM, Inc. headquarters at 10050 North Wolfe Road, * SW2-130, Cupertino, CA 95014, USA. or at email address contact@sugarcrm.com. *  * The interactive user interfaces in modified source and object code versions * of this program must display Appropriate Legal Notices, as required under * Section 5 of the GNU General Public License version 3. *  * In accordance with Section 7(b) of the GNU General Public License version 3, * these Appropriate Legal Notices must retain the display of the "Powered by * SugarCRM" logo. If the display of the logo is not reasonably feasible for * technical reasons, the Appropriate Legal Notices must display the words * "Powered by SugarCRM". ********************************************************************************/
/*********************************************************************************
 * $Id$
 * Portions created by SugarCRM are Copyright (C) SugarCRM, Inc.
 * All Rights Reserved.
 * Contributor(s): ______________________________________..
 ********************************************************************************/
 
require_once('modules/Trackers/store/Store.php');

class TrackerQueriesDatabaseStore implements Store {
    
    public function flush($monitor) {

       $metrics = $monitor->getMetrics();
       $columns = array();
       $values = array();
       foreach($metrics as $name=>$metric) {
       	  if(!empty($monitor->$name)) {
       	  	 $columns[] = $name;
       	  	 if($metrics[$name]->_type == 'int' || $metrics[$name]->_type == 'double') {
                $values[] = PearDatabase::quote(from_html($monitor->$name));
             } else if ($metrics[$name]->_type == 'datetime') {
             	$values[] = ($GLOBALS['db']->dbType == 'oci8') ? db_convert("'".$monitor->$name."'",'datetime') : "'".$monitor->$name."'";
       	  	 } else {
                $values[] = "'".PearDatabase::quote(from_html($monitor->$name))."'";
             } 
       	  }
       } //foreach
       
       if(empty($values)) {
       	  return;
       }
       
	   $db = & PearDatabase::getInstance();
	   $query = "DELETE FROM $monitor->table_name WHERE query_hash ='$monitor->query_hash'";
	   $db->query($query);
	   
	   //If it's Oracle, we have to do special handling for the text column (CLOB type)	
	   if($GLOBALS['db']->dbType == 'oci8') {
          $query = "INSERT INTO $monitor->table_name (" .implode("," , $columns). " ) VALUES ( ". implode("," , $values). ')';

		  $lob_fields = array();
		  $lob_field_type = array();
		  $lobs = array();
		  
		  //Add text as the lob field
		  $lob_fields['text'] = ":". 'text';
		  $lob_field_type['text'] = OCI_B_CLOB;
		
		  $query .= " RETURNING ".implode(",", array_keys($lob_fields)).' INTO '.implode(",", array_values($lob_fields));
		
		  $stmt = ociparse($db->database, $query);
		  $err = ocierror($db->database);
		  if ($err != false){
		      $GLOBALS['log']->error($query.">>".$err['code'].":".$err['message']);
		      return;
		  }

		  foreach ($lob_fields as $key=>$descriptor) {
		    $newlob = OCINewDescriptor($db->database, OCI_D_LOB);
		    OCIBindByName($stmt, $descriptor, $newlob, -1, $lob_field_type[$key]);
		    $lobs[$key] = $newlob;
		  }
		
		  ociexecute($stmt,OCI_DEFAULT);
		  $err = ocierror($stmt);
		  if ($err != false){
			  $GLOBALS['log']->fatal($query.">>".$err['code'].":".$err['message']);
			  return;
		  } else {
			  foreach ($lobs as $key=>$lob){
			        $val = $monitor->$key;
			        if (empty($val)) $val=" ";
			        $lob->save($val);
			  }
			  ocicommit($db->database);
		  }
		
		  // free all the lobs.
		  foreach ($lobs as $lob){
		    $lob->free();
		  }
		  ocifreecursor($stmt);
	      
	   } else {
          $query = "INSERT INTO $monitor->table_name (" .implode("," , $columns). " ) VALUES ( ". implode("," , $values). ')';
	      $db->query($query);	   	
	   }
    }
}

?>

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -