Linux ip-172-26-7-228 5.4.0-1103-aws #111~18.04.1-Ubuntu SMP Tue May 23 20:04:10 UTC 2023 x86_64
Your IP : 18.188.211.58
Current Path : /var/www/oasis/src/ |
| Current File : /var/www/oasis/src/create_all_views.php |
<?php
function CreateView($aobj_context)
{
$aobj_context->mobj_db->SetFetchMode(ADODB_FETCH_ASSOC);
$schema_id =$aobj_context->mobj_data["schema_id"];
$schema_cond='';
if(!($schema_id==0 or $schema_id=='0'))
{
$schema_cond=" and s.internal_code={$schema_id} ";
}
if($schema_id==1)
{
$schema_cond="";// and s.internal_code=39
}
$get_schema_id="SELECT s.internal_code,s.module_name
from s_user_schema s inner join s_ref_type t
on t.internal_code=s.module_type
where is_menu_only=0 and value<>'Reports'
{$schema_cond}
order by 1
";
//echo $get_schema_id;
// die();
$lobj_get_schema_id = $aobj_context->mobj_db->GetAll($get_schema_id);
foreach($lobj_get_schema_id as $key1=>$schema_value)
{
$module_id=$schema_value['internal_code'];
$module_name=$schema_value['module_name'];
CreateGeneralMasterView($aobj_context,$module_id,$module_name);
CreateGroupView($aobj_context,$module_id,$module_name);
}
if(($schema_id==0 or $schema_id=='0'))
{
$data="Views Created Successfully";
echo $aobj_context->mobj_output->ToJSONEnvelope($data,0,"success");
return;
}
}
function getViewName($name)
{
$spl_char = array("*","/","~","!","@","#","$","%","^","&",":",";","?","/","\\","_","-","'"," ",".");
$view_name = strtolower(str_replace($spl_char,"_",$name));
return str_ireplace("__","_",$view_name);
}
function CreateGeneralMasterView($aobj_context,$schema_id,$module_name)
{
$view_name =getViewName($module_name);
$aobj_context->mobj_db->execute("SET @@session.group_concat_max_len=100000");
$aobj_context->mobj_db->execute("set @a:=0");
$table_name="module_{$schema_id}";
$select_ref_module_code="select
GROUP_CONCAT(join_table_name SEPARATOR ' ') as qry from
(select @a:=@a+1,ref_module_code,
concat(' left join module_',ref_module_code, ' as module_',ref_module_code,'_',internal_code,' on module_',ref_module_code,'_',internal_code,'.internal_code =module_',ref_s_user_schema_code,'.m_',ref_s_user_schema_code, '_ele_',internal_code) as join_table_name
from s_user_schema_elements
where ref_s_user_schema_code={$schema_id}
and is_multiple_group=0 and ref_module_code>0)j";
$obj_select_ref_module_code = $aobj_context->mobj_db->GetRow($select_ref_module_code);
$join_qry=(count($obj_select_ref_module_code)>0)?$obj_select_ref_module_code[qry]:'';
$get_display_cols="select GROUP_CONCAT(field_name) as field_name from
(select table_name,name,field_name as grid_field_name,
if(ref_module_code=0,
concat('module_',internal_code,'.',field_name,' as ', name),
concat(\"concat(\",f1,f2,\") as \",name,',module_',internal_code,'.',field_name, ' as ref_',name,'_code')) as field_name
,ref_module_code from
(select s.internal_code, su.internal_code as ele_id,
ref_module_code,concat('module_',s.internal_code) as table_name ,
field_id,
if(ifnull(field_id1,'')!='',concat('module_',ref_module_code,'_',su.internal_code,'.',field_id1),'') as f1,
if(ifnull(field_id2,'')!='',concat(',\'-\',module_',ref_module_code,'_',su.internal_code,'.',field_id2),'') as f2,
LCASE(REPLACE(REPLACE(REPLACE(REPLACE(su.system_name,' ','_'),'.','_'),'&','_'),'/','_')) as name
,
ifnull(multiple,0) as multiple,ifnull(ug.name,'0None') as group_name,
concat('m_',s.internal_code,'_ele_',su.internal_code) as field_name
from s_user_schema s inner join s_user_schema_elements su on
su.ref_s_user_schema_code=s.internal_code
inner join s_ref_type t on t.internal_code=su.s_ref_type_meta
left join s_user_schema_group ug on ug.internal_code=su.ref_s_user_schema_group_code
left join module_meta_columns mmc on mmc.module_id=su.ref_module_code
where s.internal_code={$schema_id} and t.value='Meta'
and (ug.parent_group_code is null or ug.parent_group_code=0)
order by ug.sequence,su.sequence,su.internal_code ) l
where multiple=0
) a ";
$lobj_get_display_cols = $aobj_context->mobj_db->GetRow($get_display_cols);
$field_name=$lobj_get_display_cols[field_name];
$SQL = " create view {$view_name} as select {$table_name}.internal_code,{$field_name},
{$table_name}.created_by,
{$table_name}.created_date,
{$table_name}.modified_by,
{$table_name}.modified_date
from {$table_name} {$join_qry}";
//if($table_name == 'module_30')
$drop_view="DROP VIEW IF EXISTS {$view_name}";
$lobj_drop_view = $aobj_context->mobj_db->Execute($drop_view);
$lobj_SQL= $aobj_context->mobj_db->Execute($SQL);
//echo mysql_error();
}
function CreateGroupView_old($aobj_context,$schema_id,$module_name)
{
$get_groups="select internal_code,name
from s_user_schema_group
where ref_s_user_schema_code={$schema_id}
and multiple=1";
$lobj_get_groups = $aobj_context->mobj_db->GetAll($get_groups);
foreach($lobj_get_groups as $key=>$val)
{
$fields='';
$join_qry='';
$group_id=$val[internal_code];
$group_name=$val[name];
$group_view_name=getViewName($module_name."_".$group_name);
$entry_view_name=getViewName($module_name."_".$group_name."_entry");
$group_table_name="user_schema_{$schema_id}_group_{$group_id}";
$entry_table_name="user_schema_{$schema_id}_entry_{$group_id}";
$aobj_context->mobj_db->execute("SET @@session.group_concat_max_len=10000");
$select_ref_module_code="select GROUP_CONCAT(join_table_name SEPARATOR ' ') as qry from
(select ref_module_code,
concat('u_',{$schema_id},'_g_',{$group_id},'_ele_',internal_code) as field_id,
concat(' left join module_',ref_module_code, ' on module_',ref_module_code,'.internal_code =u_',{$schema_id},'_g_',{$group_id},'_ele_',internal_code) as join_table_name
from s_user_schema_elements
where ref_s_user_schema_code={$schema_id}
and ref_s_user_schema_group_code={$group_id} and ref_module_code>0)j";
$obj_select_ref_module_code = $aobj_context->mobj_db->GetRow($select_ref_module_code);
$join_qry=(count($obj_select_ref_module_code)>0)?$obj_select_ref_module_code[qry]:'';
// to form the fields dynamically
$select_field_ids="select
concat('u_',{$schema_id},'_g_',{$group_id},'_ele_',internal_code) as field_id,
LCASE(REPLACE(REPLACE(REPLACE(REPLACE(system_name,' ','_'),'.','_'),'&','_'),'/','_')) as name,
ref_module_code from
s_user_schema_elements
where ref_s_user_schema_code={$schema_id}
and ref_s_user_schema_group_code={$group_id}
order by internal_code";
$lobj_select_field_ids = $aobj_context->mobj_db->GetAll($select_field_ids);
foreach($lobj_select_field_ids as $key =>$value)
{
if($value[ref_module_code]=='0')
{
$fields.=$value[field_id]." as $value[name],";
}
else
{
$aobj_context->mobj_db->execute("SET @@session.group_concat_max_len=10000");
$qry=" select concat('module_',schema_id) as table_name,GROUP_CONCAT(name SEPARATOR '-ele-') as name,
GROUP_CONCAT(field_name separator ',\'-\',') as field_name from
(select * from
(select s.internal_code as schema_id,su.name,ifnull(multiple,0) as multiple,ifnull(ug.name,'0None') as group_name,
concat('m_',s.internal_code,'_ele_',su.internal_code) as field_name
from s_user_schema s inner join s_user_schema_elements su on
su.ref_s_user_schema_code=s.internal_code
inner join s_ref_type t on t.internal_code=su.s_ref_type_meta
left join s_user_schema_group ug on ug.internal_code=su.ref_s_user_schema_group_code
where s.internal_code=$value[ref_module_code] and t.value='Meta'
order by ug.sequence,su.sequence,su.internal_code ) l where multiple=0 limit 2) a group by schema_id";
$lobj_rs = $aobj_context->mobj_db->GetRow($qry);
$fields.="concat(".$lobj_rs[field_name].") as {$value[name]}".", {$value[field_id]} as ref_{$value[name]}_code ,";
}
}
$fields=substr($fields,0,strlen($fields)-1);
$create_group_view=" create view {$group_view_name} as
select {$group_table_name}.internal_code ,ref_s_ref_data_code,{$fields}
from
{$group_table_name}
{$join_qry}";
$drop_view="DROP VIEW IF EXISTS {$group_view_name}";
$lobj_drop_view = $aobj_context->mobj_db->Execute($drop_view);
$lobj_SQL= $aobj_context->mobj_db->Execute($create_group_view);
$create_entry_view=" create view {$entry_view_name} as
select {$entry_table_name}.internal_code ,login_cnt,group_int_code,
ref_s_ref_data_code,{$fields}
from
{$entry_table_name}
{$join_qry}";
$drop_entry_view="DROP VIEW IF EXISTS {$entry_view_name}";
$lobj_drop_view = $aobj_context->mobj_db->Execute($drop_entry_view);
$lobj_SQL= $aobj_context->mobj_db->Execute($create_entry_view);
}
}
function CreateGroupView($aobj_context,$schema_id,$module_name)
{
$get_groups="select internal_code,name
from s_user_schema_group
where ref_s_user_schema_code={$schema_id}
and multiple=1";
$lobj_get_groups = $aobj_context->mobj_db->GetAll($get_groups);
foreach($lobj_get_groups as $key=>$val)
{
$fields='';
$join_qry='';
$group_id=$val[internal_code];
$group_name=$val[name];
$group_view_name=getViewName($module_name."_".$group_name);
$entry_view_name=getViewName($module_name."_".$group_name."_entry");
$group_table_name="user_schema_{$schema_id}_group_{$group_id}";
$entry_table_name="user_schema_{$schema_id}_entry_{$group_id}";
$aobj_context->mobj_db->execute("SET @@session.group_concat_max_len=10000");
/* $select_ref_module_code="select GROUP_CONCAT(join_table_name SEPARATOR ' ') as qry from
(select ref_module_code,
concat('u_',{$schema_id},'_g_',{$group_id},'_ele_',internal_code) as field_id,
concat(' left join module_',ref_module_code, ' on module_',ref_module_code,'.internal_code =u_',{$schema_id},'_g_',{$group_id},'_ele_',internal_code) as join_table_name
from s_user_schema_elements
where ref_s_user_schema_code={$schema_id}
and ref_s_user_schema_group_code={$group_id} and ref_module_code>0)j";
$obj_select_ref_module_code = $aobj_context->mobj_db->GetRow($select_ref_module_code);
$join_qry=(count($obj_select_ref_module_code)>0)?$obj_select_ref_module_code[qry]:'';
// to form the fields dynamically
$select_field_ids="select
concat('u_',{$schema_id},'_g_',{$group_id},'_ele_',internal_code) as field_id,
LCASE(REPLACE(REPLACE(REPLACE(REPLACE(system_name,' ','_'),'.','_'),'&','_'),'/','_')) as name,
ref_module_code from
s_user_schema_elements
where ref_s_user_schema_code={$schema_id}
and ref_s_user_schema_group_code={$group_id}
order by internal_code";
$lobj_select_field_ids = $aobj_context->mobj_db->GetAll($select_field_ids);
foreach($lobj_select_field_ids as $key =>$value)
{
if($value[ref_module_code]=='0')
{
$fields.=$value[field_id]." as $value[name],";
}
else
{
$aobj_context->mobj_db->execute("SET @@session.group_concat_max_len=10000");
$qry=" select concat('module_',schema_id) as table_name,GROUP_CONCAT(name SEPARATOR '-ele-') as name,
GROUP_CONCAT(field_name separator ',\'-\',') as field_name from
(select * from
(select s.internal_code as schema_id,su.name,ifnull(multiple,0) as multiple,ifnull(ug.name,'0None') as group_name,
concat('m_',s.internal_code,'_ele_',su.internal_code) as field_name
from s_user_schema s inner join s_user_schema_elements su on
su.ref_s_user_schema_code=s.internal_code
inner join s_ref_type t on t.internal_code=su.s_ref_type_meta
left join s_user_schema_group ug on ug.internal_code=su.ref_s_user_schema_group_code
where s.internal_code=$value[ref_module_code] and t.value='Meta'
order by ug.sequence,su.sequence,su.internal_code ) l where multiple=0 limit 2) a group by schema_id";
$lobj_rs = $aobj_context->mobj_db->GetRow($qry);
$fields.="concat(".$lobj_rs[field_name].") as {$value[name]}".", {$value[field_id]} as ref_{$value[name]}_code ,";
}
}
$fields=substr($fields,0,strlen($fields)-1); */
$group_qry=getGroupDetailsViewQry($aobj_context,$schema_id,$group_id,$group_table_name);
$create_group_view=" create view {$group_view_name} as
select {$group_table_name}.internal_code ,ref_s_ref_data_code,{$group_qry}";
$drop_view="DROP VIEW IF EXISTS {$group_view_name}";
$lobj_drop_view = $aobj_context->mobj_db->Execute($drop_view);
$lobj_SQL= $aobj_context->mobj_db->Execute($create_group_view);
$entry_group_qry=getGroupDetailsViewQry($aobj_context,$schema_id,$group_id,$entry_table_name);
$create_entry_view=" create view {$entry_view_name} as
select {$entry_table_name}.internal_code ,login_cnt,group_int_code,
ref_s_ref_data_code,{$entry_group_qry}
";
$drop_entry_view="DROP VIEW IF EXISTS {$entry_view_name}";
$lobj_drop_view = $aobj_context->mobj_db->Execute($drop_entry_view);
$lobj_SQL= $aobj_context->mobj_db->Execute($create_entry_view);
}
}
function getGroupDetailsViewQry($aobj_context,$schema_id,$group_id,$table_name)
{
$aobj_context->mobj_db->execute("SET @@session.group_concat_max_len=10000");
$aobj_context->mobj_db->execute("set @a:=0");
$select_ref_module_code="select
GROUP_CONCAT(join_table_name SEPARATOR ' ') as qry from
(select parent_group_code,ref_s_user_schema_group_code, @a:=@a+1,ref_module_code,
concat(' left join module_',suse.ref_module_code, ' as module_',suse.ref_module_code,'_',suse.internal_code,' on module_',suse.ref_module_code,'_',suse.internal_code,'.internal_code =',suse.db_field) as join_table_name
from s_user_schema_elements suse
inner join s_user_schema_group ug on ug.internal_code=suse.ref_s_user_schema_group_code
where suse.ref_s_user_schema_code={$schema_id}
and (is_multiple_group=1 or parent_group_code<>0)
and (ref_s_user_schema_group_code={$group_id})
and ref_module_code>0)j";
$obj_select_ref_module_code = $aobj_context->mobj_db->GetRow($select_ref_module_code);
$join_qry=(count($obj_select_ref_module_code)>0)?$obj_select_ref_module_code[qry]:'';
$get_display_cols="select GROUP_CONCAT(field_name) as field_name from
(select table_name,name,field_name as grid_field_name,
if(ref_module_code=0,
concat(field_name, ' as ',name) ,
concat(\"concat(\",f1,f2,\") as \",name,' , ',field_name, ' as ref_',name,'_code')) as field_name
,ref_module_code from
(select s.internal_code, su.internal_code as ele_id,
ref_module_code,concat('module_',s.internal_code) as table_name ,
field_id,
if(ifnull(field_id1,'')!='',concat('module_',ref_module_code,'_',su.internal_code,'.',field_id1),'') as f1,
if(ifnull(field_id2,'')!='',concat(',\'-\',module_',ref_module_code,'_',su.internal_code,'.',field_id2),'') as f2,
LCASE(REPLACE(REPLACE(REPLACE(REPLACE(su.system_name,' ','_'),'.','_'),'&','_'),'/','_')) as name
,ifnull(multiple,0) as multiple,ifnull(ug.name,'0None') as group_name,
db_field as field_name
from s_user_schema s inner join s_user_schema_elements su on
su.ref_s_user_schema_code=s.internal_code
inner join s_ref_type t on t.internal_code=su.s_ref_type_meta
left join s_user_schema_group ug on ug.internal_code=su.ref_s_user_schema_group_code
left join module_meta_columns mmc on mmc.module_id=su.ref_module_code
where s.internal_code={$schema_id} and t.value='Meta'
and (ug.internal_code={$group_id} or
(parent_group_code={$group_id} and is_grid_edit = '0' and is_multiple_group=0)
)
order by ifnull(ug.sequence,0),su.sequence,su.internal_code ) l
) a ";
$lobj_get_display_cols = $aobj_context->mobj_db->GetRow($get_display_cols);
$qry = "{$lobj_get_display_cols[field_name]},
{$table_name}.created_by,
{$table_name}.created_date,
{$table_name}.modified_by,
{$table_name}.modified_date from
{$table_name} {$join_qry}";
return $qry;
}
?>
|