当前位置: 首页>>代码示例>>PHP>>正文


PHP rcube_db::list_tables方法代码示例

本文整理汇总了PHP中rcube_db::list_tables方法的典型用法代码示例。如果您正苦于以下问题:PHP rcube_db::list_tables方法的具体用法?PHP rcube_db::list_tables怎么用?PHP rcube_db::list_tables使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在rcube_db的用法示例。


在下文中一共展示了rcube_db::list_tables方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的PHP代码示例。

示例1: db_schema_check

 /**
  * Compare the local database schema with the reference schema
  * required for this version of Roundcube
  *
  * @param rcube_db $db Database object
  *
  * @return boolean True if the schema is up-to-date, false if not or an error occurred
  */
 public function db_schema_check($db)
 {
     if (!$this->configured) {
         return false;
     }
     // read reference schema from mysql.initial.sql
     $db_schema = $this->db_read_schema(INSTALL_PATH . 'SQL/mysql.initial.sql');
     $errors = array();
     // check list of tables
     $existing_tables = $db->list_tables();
     foreach ($db_schema as $table => $cols) {
         $table = $this->config['db_prefix'] . $table;
         if (!in_array($table, $existing_tables)) {
             $errors[] = "Missing table '" . $table . "'";
         } else {
             // compare cols
             $db_cols = $db->list_cols($table);
             $diff = array_diff(array_keys($cols), $db_cols);
             if (!empty($diff)) {
                 $errors[] = "Missing columns in table '{$table}': " . join(',', $diff);
             }
         }
     }
     return !empty($errors) ? $errors : false;
 }
开发者ID:jimjag,项目名称:roundcubemail,代码行数:33,代码来源:rcmail_install.php


注:本文中的rcube_db::list_tables方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。