1
0
Fork 0
mirror of https://github.com/Oreolek/ifhub.club.git synced 2024-07-05 07:54:24 +03:00

fix update in ORM Issue #41 + small fixes ORM

This commit is contained in:
Mzhelskiy Maxim 2012-02-08 19:06:18 +04:00
parent 355b5efb69
commit 65f5dc9d81
3 changed files with 93 additions and 21 deletions

View file

@ -60,7 +60,7 @@ abstract class EntityORM extends Entity {
* *
* @var unknown_type * @var unknown_type
*/ */
protected $sPrimaryKey='id'; protected $sPrimaryKey=null;
/** /**
* Флаг новая или нет сущность * Флаг новая или нет сущность
* *
@ -77,15 +77,16 @@ abstract class EntityORM extends Entity {
/** /**
* Получение primary key из схемы таблицы * Получение primary key из схемы таблицы
* *
* @return unknown * @return string | array
*/ */
public function _getPrimaryKey() { public function _getPrimaryKey() {
if(!$this->_getDataOne($this->sPrimaryKey)) { if(!$this->sPrimaryKey) {
if($this->_getFields()) { if ($aIndex=$this->ShowPrimaryIndex()) {
if(array_key_exists('#primary_key',$this->aFields)) { if (count($aIndex)>1) {
$this->sPrimaryKey = $this->aFields['#primary_key']; // Составной индекс
$this->sPrimaryKey=$aIndex;
} else { } else {
$this->sPrimaryKey = $this->_getField($this->sPrimaryKey,2); $this->sPrimaryKey=$aIndex[1];
} }
} }
} }
@ -193,6 +194,15 @@ abstract class EntityORM extends Entity {
return $this->_Method(__FUNCTION__ .'From'); return $this->_Method(__FUNCTION__ .'From');
} }
/**
* Primary индекс сущности
*
* @return unknown
*/
public function ShowPrimaryIndex() {
return $this->_Method(__FUNCTION__ .'From');
}
/** /**
* Хук, срабатывает перед сохранением сущности * Хук, срабатывает перед сохранением сущности
* *
@ -515,7 +525,7 @@ abstract class EntityORM extends Entity {
$sRelEntityName=Engine::GetEntityName($sEntityRel); $sRelEntityName=Engine::GetEntityName($sEntityRel);
$sRelPluginPrefix=Engine::GetPluginPrefix($sEntityRel); $sRelPluginPrefix=Engine::GetPluginPrefix($sEntityRel);
$sRelPrimaryKey='id'; $sRelPrimaryKey='id';
if($oRelEntity=Engine::GetEntity($sEntityRel) and method_exists($oRelEntity,'_getPrimaryKey')) { // для совместимости с сущностями Entity if($oRelEntity=Engine::GetEntity($sEntityRel)) {
$sRelPrimaryKey=$oRelEntity->_getPrimaryKey(); $sRelPrimaryKey=$oRelEntity->_getPrimaryKey();
} }
@ -558,10 +568,10 @@ abstract class EntityORM extends Entity {
// Сохраняем данные только в случае "чистой" выборки // Сохраняем данные только в случае "чистой" выборки
if(!$bUseFilter) { if(!$bUseFilter) {
$this->aRelationsData[$sKey]=$res; $this->aRelationsData[$sKey]=$res;
// Создаём объекты-обёртки для связей MANY_TO_MANY }
if ($sRelationType == self::RELATION_TYPE_MANY_TO_MANY) { // Создаём объекты-обёртки для связей MANY_TO_MANY
$this->_aManyToManyRelations[$sKey] = new LS_ManyToManyRelation($this->aRelationsData[$sKey]); if ($sRelationType == self::RELATION_TYPE_MANY_TO_MANY) {
} $this->_aManyToManyRelations[$sKey] = new LS_ManyToManyRelation($res);
} }
return $res; return $res;
} }

View file

@ -42,11 +42,18 @@ class MapperORM extends Mapper {
*/ */
public function UpdateEntity($oEntity) { public function UpdateEntity($oEntity) {
$sTableName = self::GetTableName($oEntity); $sTableName = self::GetTableName($oEntity);
$iPrimaryKeyValue=$oEntity->_getDataOne($oEntity->_getPrimaryKey());
if($aPrimaryKey=$oEntity->_getPrimaryKey()) {
if(!empty($iPrimaryKeyValue)) { // Возможен составной ключ
$sql = "UPDATE ".$sTableName." SET ?a WHERE ".$oEntity->_getPrimaryKey()." = ? "; if (!is_array($aPrimaryKey)) {
return $this->oDb->query($sql,$oEntity->_getData(),$iPrimaryKeyValue); $aPrimaryKey=array($aPrimaryKey);
}
$sWhere=' 1 = 1 ';
foreach ($aPrimaryKey as $sField) {
$sWhere.=' and '.$this->oDb->escape($sField,true)." = ".$this->oDb->escape($oEntity->_getDataOne($sField));
}
$sql = "UPDATE ".$sTableName." SET ?a WHERE {$sWhere}";
return $this->oDb->query($sql,$oEntity->_getData());
} else { } else {
$aOriginalData = $oEntity->_getOriginalData(); $aOriginalData = $oEntity->_getOriginalData();
$sWhere = implode(' AND ',array_map(create_function( $sWhere = implode(' AND ',array_map(create_function(
@ -66,11 +73,18 @@ class MapperORM extends Mapper {
*/ */
public function DeleteEntity($oEntity) { public function DeleteEntity($oEntity) {
$sTableName = self::GetTableName($oEntity); $sTableName = self::GetTableName($oEntity);
$iPrimaryKeyValue=$oEntity->_getDataOne($oEntity->_getPrimaryKey());
if(!empty($iPrimaryKeyValue)) { if($aPrimaryKey=$oEntity->_getPrimaryKey()) {
$sql = "DELETE FROM ".$sTableName." WHERE ".$oEntity->_getPrimaryKey()." = ? "; // Возможен составной ключ
return $this->oDb->query($sql,$iPrimaryKeyValue); if (!is_array($aPrimaryKey)) {
$aPrimaryKey=array($aPrimaryKey);
}
$sWhere=' 1 = 1 ';
foreach ($aPrimaryKey as $sField) {
$sWhere.=' and '.$this->oDb->escape($sField,true)." = ".$this->oDb->escape($oEntity->_getDataOne($sField));
}
$sql = "DELETE FROM ".$sTableName." WHERE {$sWhere}";
return $this->oDb->query($sql);
} else { } else {
$aOriginalData = $oEntity->_getOriginalData(); $aOriginalData = $oEntity->_getOriginalData();
$sWhere = implode(' AND ',array_map(create_function( $sWhere = implode(' AND ',array_map(create_function(
@ -341,6 +355,39 @@ class MapperORM extends Mapper {
return $aItems; return $aItems;
} }
/**
* Primary индекс сущности
*
* @param unknown_type $oEntity
* @return unknown
*/
public function ShowPrimaryIndexFrom($oEntity) {
$sTableName = self::GetTableName($oEntity);
return $this->ShowPrimaryIndexFromTable($sTableName);
}
/**
* Primary индекс таблицы
*
* @param unknown_type $sTableName
* @return unknown
*/
public function ShowPrimaryIndexFromTable($sTableName) {
if (false === ($aItems = Engine::getInstance()->Cache_GetLife("index_table_{$sTableName}"))) {
$sql = "SHOW INDEX FROM ".$sTableName;
$aItems = array();
if($aRows=$this->oDb->select($sql)) {
foreach($aRows as $aRow) {
if ($aRow['Key_name']=='PRIMARY') {
$aItems[$aRow['Seq_in_index']]=$aRow['Column_name'];
}
}
}
Engine::getInstance()->Cache_SetLife($aItems, "index_table_{$sTableName}");
}
return $aItems;
}
/** /**
* Возвращает имя таблицы для сущности * Возвращает имя таблицы для сущности
* *

View file

@ -172,6 +172,17 @@ abstract class ModuleORM extends Module {
return $res; return $res;
} }
/**
* Primary индекс сущности
*
* @param unknown_type $oEntity
* @return unknown
*/
protected function _ShowPrimaryIndexFrom($oEntity) {
$res=$this->oMapperORM->ShowPrimaryIndexFrom($oEntity);
return $res;
}
/** /**
* Для сущности со связью RELATION_TYPE_TREE возвращает список прямых потомков * Для сущности со связью RELATION_TYPE_TREE возвращает список прямых потомков
* *
@ -619,6 +630,10 @@ abstract class ModuleORM extends Module {
return $this->_ShowColumnsFrom($aArgs[0]); return $this->_ShowColumnsFrom($aArgs[0]);
} }
if (preg_match("@^showprimaryindexfrom([\w]+)$@i",$sName,$aMatch)) {
return $this->_ShowPrimaryIndexFrom($aArgs[0]);
}
if (preg_match("@^getchildrenof([\w]+)$@i",$sName,$aMatch)) { if (preg_match("@^getchildrenof([\w]+)$@i",$sName,$aMatch)) {
return $this->_GetChildrenOfEntity($aArgs[0]); return $this->_GetChildrenOfEntity($aArgs[0]);
} }