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:
parent
355b5efb69
commit
65f5dc9d81
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
|
@ -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;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Возвращает имя таблицы для сущности
|
* Возвращает имя таблицы для сущности
|
||||||
*
|
*
|
||||||
|
|
|
@ -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]);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue