diff --git a/engine/classes/Plugin.class.php b/engine/classes/Plugin.class.php index 8a07bd05..75019332 100644 --- a/engine/classes/Plugin.class.php +++ b/engine/classes/Plugin.class.php @@ -194,6 +194,17 @@ abstract class Plugin extends Object { return $this->Database_isTableExists($sTableName); } + /** + * Проверяет наличие поля в таблице + * + * @param unknown_type $sTableName + * @param unknown_type $sFieldName + * @return unknown + */ + protected function isFieldExists($sTableName,$sFieldName) { + return $this->Database_isFieldExists($sTableName,$sFieldName); + } + /** * Получает версию плагина * diff --git a/engine/modules/database/Database.class.php b/engine/modules/database/Database.class.php index 3570e275..219113fe 100644 --- a/engine/modules/database/Database.class.php +++ b/engine/modules/database/Database.class.php @@ -162,6 +162,13 @@ class ModuleDatabase extends Module { return array('result'=>false,'errors'=>$aErrors); } + /** + * Проверяет существование таблицы + * + * @param string $sTableName + * @param array $aConfig + * @return bool + */ public function isTableExists($sTableName,$aConfig=null) { $sTableName = str_replace('prefix_', Config::Get('db.table.prefix'), $sTableName); $sQuery="SHOW TABLES LIKE '{$sTableName}'"; @@ -170,6 +177,27 @@ class ModuleDatabase extends Module { } return false; } + + /** + * Проверяет существование поля в таблице + * + * @param string $sTableName + * @param string $sFieldName + * @param array $aConfig + * @return bool + */ + public function isFieldExists($sTableName,$sFieldName,$aConfig=null) { + $sTableName = str_replace('prefix_', Config::Get('db.table.prefix'), $sTableName); + $sQuery="SHOW FIELDS FROM '{$sTableName}'"; + if ($aRows=$this->GetConnect($aConfig)->select($sQuery)) { + foreach ($aRows as $aRow){ + if ($aRow['Field'] == $sFieldName){ + return true; + } + } + } + return false; + } }