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


PHP eZPersistentObject::conditionText方法代碼示例

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


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

示例1: newObjectOrder

 /**
  * Returns an order value which can be used for new items in table,
  * for instance placement.
  *
  * Uses $def, $orderField and $conditions to figure out the currently maximum
  * order value and returns one that is larger.
  *
  * @param array $def A definition array of all fields, table name and sorting (see {@link eZPersistentObject::definition()} for more info)
  * @param string $orderField
  * @param array $conditions
  * @return int
  */
 public static function newObjectOrder($def, $orderField, $conditions)
 {
     $db = eZDB::instance();
     $table = $def["name"];
     $keys = $def["keys"];
     $cond_text = eZPersistentObject::conditionText($conditions);
     $rows = $db->arrayQuery("SELECT MAX({$orderField}) AS {$orderField} FROM {$table} {$cond_text}");
     if (count($rows) > 0 and isset($rows[0][$orderField])) {
         return $rows[0][$orderField] + 1;
     } else {
         return 1;
     }
 }
開發者ID:mugoweb,項目名稱:ezpublish-legacy,代碼行數:25,代碼來源:ezpersistentobject.php

示例2: storeObject


//.........這裏部分代碼省略.........
             if ($field_def['datatype'] == 'float' || $field_def['datatype'] == 'double') {
                 if ($value === null) {
                     $use_values_hash[$key] = 'NULL';
                 } else {
                     $use_values_hash[$key] = sprintf('%F', $value);
                 }
             } else {
                 if ($field_def['datatype'] == 'int' || $field_def['datatype'] == 'integer') {
                     if ($value === null) {
                         $use_values_hash[$key] = 'NULL';
                     } else {
                         $use_values_hash[$key] = sprintf('%d', $value);
                     }
                 } else {
                     // Note: for more colherence, we might use NULL for sql strings if the php value is NULL and not an empty sring
                     //       but to keep compatibility with ez db, where most string columns are "not null default ''",
                     //       and code feeding us a php null value without meaning it, we do not.
                     $use_values_hash[$key] = "'" . $db->escapeString($value) . "'";
                 }
             }
         }
         foreach ($doNotEscapeFields as $key) {
             $use_values_hash[$key] = $changedValueFields[$key];
         }
         $use_values = array();
         foreach ($use_field_names as $field) {
             $use_values[] = $use_values_hash[$field];
         }
         unset($use_values_hash);
         $value_text = implode(", ", $use_values);
         $sql = "INSERT INTO {$table} ({$field_text}) VALUES({$value_text})";
         $db->query($sql);
         if (isset($def["increment_key"]) && is_string($def["increment_key"]) && !($obj->attributeContentToStore($def["increment_key"]) > 0)) {
             $inc = $def["increment_key"];
             $id = $db->lastSerialID($table, $inc);
             if ($id !== false) {
                 $obj->setAttribute($inc, $id);
             }
         }
     } else {
         $use_fields = array_diff(array_keys($fields), array_merge($keys, $exclude_fields));
         if (count($use_fields) > 0) {
             // If we filter out some of the fields we need to intersect it with $use_fields
             if (is_array($fieldFilters)) {
                 $use_fields = array_intersect($use_fields, $fieldFilters);
             }
             $use_field_names = array();
             foreach ($use_fields as $key) {
                 if ($db->useShortNames() && is_array($fields[$key]) && array_key_exists('short_name', $fields[$key]) && strlen($fields[$key]['short_name']) > 0) {
                     $use_field_names[$key] = $fields[$key]['short_name'];
                 } else {
                     $use_field_names[$key] = $key;
                 }
             }
             $field_text = "";
             $field_text_len = 0;
             $i = 0;
             foreach ($use_fields as $key) {
                 //$value = $obj->attribute( $key );
                 $value = $obj->attributeContentToStore($key);
                 if ($fields[$key]['datatype'] == 'float' || $fields[$key]['datatype'] == 'double') {
                     if ($value === null) {
                         $field_text_entry = $use_field_names[$key] . '=NULL';
                     } else {
                         $field_text_entry = $use_field_names[$key] . "=" . sprintf('%F', $value);
                     }
                 } else {
                     if ($fields[$key]['datatype'] == 'int' || $fields[$key]['datatype'] == 'integer') {
                         if ($value === null) {
                             $field_text_entry = $use_field_names[$key] . '=NULL';
                         } else {
                             $field_text_entry = $use_field_names[$key] . "=" . sprintf('%d', $value);
                         }
                     } else {
                         if (in_array($use_field_names[$key], $doNotEscapeFields)) {
                             $field_text_entry = $use_field_names[$key] . "=" . $changedValueFields[$key];
                         } else {
                             $field_text_entry = $use_field_names[$key] . "='" . $db->escapeString($value) . "'";
                         }
                     }
                 }
                 $field_text_len += strlen($field_text_entry);
                 $needNewline = false;
                 if ($field_text_len > 60) {
                     $needNewline = true;
                     $field_text_len = 0;
                 }
                 if ($i > 0) {
                     $field_text .= "," . ($needNewline ? "\n    " : ' ');
                 }
                 $field_text .= $field_text_entry;
                 ++$i;
             }
             $cond_text = eZPersistentObject::conditionText($key_conds);
             $sql = "UPDATE {$table} SET {$field_text}{$cond_text}";
             $db->query($sql);
         }
     }
     $obj->setHasDirtyData(false);
 }
開發者ID:hudri,項目名稱:cjw_newsletter,代碼行數:101,代碼來源:cjwnewsletterlistvirtual.php

示例3: newObjectOrder

 static function newObjectOrder( $def, $orderField, $conditions )
 {
     $db = eZDB::instance();
     $table = $def["name"];
     $keys = $def["keys"];
     $cond_text = eZPersistentObject::conditionText( $conditions );
     $rows = $db->arrayQuery( "SELECT MAX($orderField) AS $orderField FROM $table $cond_text" );
     if ( count( $rows ) > 0 and isset( $rows[0][$orderField] ) )
         return $rows[0][$orderField] + 1;
     else
         return 1;
 }
開發者ID:robinmuilwijk,項目名稱:ezpublish,代碼行數:12,代碼來源:ezpersistentobject.php


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