This commit is contained in:
2026-01-13 12:36:57 +03:00
commit ebe1f5bd00
29 changed files with 2295 additions and 0 deletions

View File

@@ -0,0 +1,21 @@
<?php
namespace API;
trait BOFHeatPhase
{
public function getData_BOFHeatPhase($params)
{
$query = "EXEC [Level3_KKC].[dbo].[BOFHeatPhase]
@BD = '".$params['dateStart']."',
@ED = '".$params['dateEnd']."'";
select($query);
}
public function getData_BOFHeatPhaseProstoi($params)
{
$query = "EXEC [Level3_KKC].[dbo].[BOFHeatPhaseProstoi]
@BD = '".$params['dateStart']."',
@ED = '".$params['dateEnd']."'";
select($query);
}
}

View File

@@ -0,0 +1,15 @@
<?php
namespace API;
trait BOFHeatPhaseAllStatus
{
public function getData_BOFHeatPhaseAllStatus($params)
{
$q=1;
$query = "EXEC [Level3_KKC].[dbo].[BOFHeatPhase]
@BD = '".$params['dateStart']."',
@ED = '".$params['dateEnd']."'";
select($query);
}
}

View File

@@ -0,0 +1,111 @@
<?php
namespace API;
trait BOFReport
{
public function getData_BOFReportSample_A1($params)
{
$query = "EXEC [Production].[dbo].[BOFReport_ReportIndexBof]
@dateStart = '".$params['dateStart']."',
@dateEnd = '".$params['dateEnd']."',
@aggID = '".$params['aggID']."'";
select($query);
}
public function getData_BOFReportAvgData_Marka($params)
{
$query = "EXEC [Production].[dbo].[BOFReport_ReportIndexBofMarka]
@dateStart = '".$params['dateStart']."',
@dateEnd = '".$params['dateEnd']."',
@aggID = '".$params['aggID']."'";
select_ru($query);
}
public function getDataSetpoints_BOFReportAvgData_Marka()
{
$query = "SELECT * FROM [Production].[dbo].[BofChartSetpoints]";
select_ru($query);
}
public function getData_BOFReportSample_A2($params)
{
$query = "EXEC [Production].[dbo].[BOFReport_ReportIndexBofDaily]
@dateStart = '".$params['dateStart']."',
@dateEnd = '".$params['dateEnd']."',
@aggID = '".$params['aggID']."'";
select($query);
}
public function getData_BOFReportSample_B1($params)
{
$query = "EXEC [Production].[dbo].[BOFReport_ReportMaterials]
@ds = '".$params['dateStart']."',
@de = '".$params['dateEnd']."'";
select_ru($query);
}
public function getData_BOFReportSample_C1($params)
{
$query = "EXEC [Production].[dbo].[BOFReport_GetDataForPerformanceIndicators]
@ds = '".$params['dateStart']."',
@de = '".$params['dateEnd']."',
@agg = 0";
select_ru($query);
}
public function getData_BOFReportSample_D1($params)
{
$query = "EXEC [Production].[dbo].[BOFReport_GetDataForAnalizHeatsReport]
@ds = '".$params['dateStart']."',
@de = '".$params['dateEnd']."'";
select_ru($query);
}
public function getData_BOFReportSample_D1_countHets($params)
{
$query = "EXEC [Production].[dbo].[BOFReport_GetCountAndPercentCheckedHeatsFromAllHeats]
@ds = '".$params['dateStart']."',
@de = '".$params['dateEnd']."'";
select_ru($query);
}
public function getData_BOFReportSample_D1_sampleCounts($params)
{
$query = "EXEC [Production].[dbo].[BOFReport_GetCountsAndPercentForAnalizHeatsReport]
@ds = '".$params['dateStart']."',
@de = '".$params['dateEnd']."'";
select_ru($query);
}
public function getData_BOFReportSample_D1_master($params)
{
$query = "EXEC [Production].[dbo].[BOFReport_GetCountCheckedHeatsGroupBOFMaster]
@ds = '".$params['dateStart']."',
@de = '".$params['dateEnd']."'";
select_ru($query);
}
public function getData_BOFReportSample_D1_operator($params)
{
$query = "EXEC [Production].[dbo].[BOFReport_GetCountCheckedHeatsGroupBOFOperator]
@ds = '".$params['dateStart']."',
@de = '".$params['dateEnd']."'";
select_ru($query);
}
public function getData_BOFReportSample_D1_shift($params)
{
$query = "EXEC [Production].[dbo].[BOFReport_GetCountCheckedHeatsGroupShiftTeamNo]
@ds = '".$params['dateStart']."',
@de = '".$params['dateEnd']."'";
select_ru($query);
}
public function getData_BOFReportSample_D1_avgData($params)
{
$query = "EXEC [Production].[dbo].[BOFReport_GetAVGDataForAnalizHeatsReport]
@ds = '".$params['dateStart']."',
@de = '".$params['dateEnd']."'";
select_ru($query);
}
public function getData_BOFMainUseConfig($params)
{
$query = "EXEC [Production].[dbo].[Raport_BOF_MainUseConfig]
@dateStart = '".$params['dateStart']."',
@dateEnd = '".$params['dateEnd']."',
@aggID = '".$params['aggID']."'";
select_ru($query);
}
}

View File

@@ -0,0 +1,119 @@
<?php
namespace API;
trait HMCarReport
{
public function getData_HMCarReport($params)
{
$query = "
SET NOCOUNT ON
SELECT
PBHR.HEAT_START
,HB.[HM_Ladle] as [КЧ]
,HB.[TorpNO] as [МП350 №]
,HB.[DC_Tap_NO] as [Номер выпуска ДЦ]
,HB.[HEAT_NUMBER] as [Номер плавки ККЦ]
,CAST(HB.[RL_Tare]/1000 as decimal(5,2)) as [Тара, т]
,CAST(HB.[RL_Gross]/1000 as decimal(5,2)) as [Брутто, т]
,CAST(HB.[RL_Net]/1000 as decimal(5,2)) as [Нетто, т]
,CAST(round([RL_Net]-([RL_Net]*0.6/100),0)/1000 as decimal(5,2)) as [Вес со снятием, т]
,0.6 as [Снятие, %]
,CAST(HB.[AFTDS_CRANEWT_Tare]/1000 as decimal(5,2)) as [Тара, т ]
,CAST(HB.[AFTDS_CRANEWT_Gross]/1000 as decimal(5,2)) as [Брутто, т ]
,CAST(HB.[AFTDS_CRANEWT_Net]/1000 as decimal(5,2)) as [Нетто, т ]
,CAST(HB.[DS_LOSS_wt] as decimal(5,2)) as [Снятие на десульфурации, т]
FROM [PasportBOF].[dbo].[PASPORT_BOFHEATREPORT] PBHR
INNER JOIN [Level3_KKC].[dbo].[HM_BALANCE] HB
ON PBHR.HEAT_NUMBER=HB.HEAT_NUMBER
WHERE (ISNULL(DELETED,0)=0) AND
(HEAT_START >= '".$params['dateStart']."')
AND (HEAT_END < '".$params['dateEnd']."')
ORDER BY [SHOW_AGGREGATE_ID], [HEAT_START]";
select($query);
// $query = "
// SET NOCOUNT ON
// DECLARE
// @BD DATETIME = '06.03.2024',
// @ED DATETIME = '08.03.2024'
// SELECT
// PBHR.HEAT_START
// ,HB.[HM_Ladle] as [КЧ]
// ,HB.[TorpNO] as [МП350 №]
// ,HB.[DC_Tap_NO] as [Номер выпуска ДЦ]
// ,HB.[HEAT_NUMBER] as [Номер плавки ККЦ]
// ,HB.[RL_Tare] as [Тара, т]
// ,HB.[RL_Gross] as [Брутто, т]
// ,HB.[RL_Net] as [Нетто, т]
// ,round([RL_Net]-([RL_Net]*0.6/100),0) as [Вес со снятием, т]
// ,0.6 as [Снятие, %]
// ,HB.[AFTDS_CRANEWT_Tare] as [Тара, т ]
// ,HB.[AFTDS_CRANEWT_Gross] as [Брутто, т ]
// ,HB.[AFTDS_CRANEWT_Net] as [Нетто, т ]
// ,HB.[DS_LOSS_wt] as [Снятие на десульфурации, т]
// FROM [PasportBOF].[dbo].[PASPORT_BOFHEATREPORT] PBHR
// INNER JOIN [Level3_KKC].[dbo].[HM_BALANCE] HB
// ON PBHR.HEAT_NUMBER=HB.HEAT_NUMBER
// WHERE (ISNULL(DELETED,0)=0) AND
// (HEAT_START >= '".$params['dateStart']."')
// AND (HEAT_START < '".$params['dateEnd']."')
// ORDER BY [SHOW_AGGREGATE_ID], [HEAT_START]";
// select($query);
// $query = "
// SELECT
// [HM_Ladle] as [КЧ]
// ,[TorpNO] as [МП350 №]
// ,[DC_Tap_NO] as [Номер выпуска ДЦ]
// ,[HEAT_NUMBER] as [Номер плавки ККЦ]
// ,[RL_Tare] as [Тара, т]
// ,[RL_Gross] as [Брутто, т]
// ,[RL_Net] as [Нетто, т]
// ,round([RL_Net]-([RL_Net]*0.6/100),0) as [Вес со снятием, т]
// ,0.6 as [Снятие, %]
// ,[AFTDS_CRANEWT_Tare] as [Тара, т ]
// ,[AFTDS_CRANEWT_Gross] as [Брутто, т ]
// ,[AFTDS_CRANEWT_Net] as [Нетто, т ]
// ,[DS_LOSS_wt] as [Снятие на десульфурации, т]
// FROM [Level3_KKC].[dbo].[HM_BALANCE]
// Where [RL_WT_TIME]>='".$params['dateStart']."' and [RL_WT_TIME] <='".$params['dateEnd']."'";
// select($query);
}
public function getData_HMCarReport_SUM($params)
{
$query = "
SELECT
sum([RL_Tare]) [RL_Tare]
,sum([RL_Gross])[RL_Gross]
,sum([RL_Net]) [RL_Net]
,sum(round([RL_Net]-([RL_Net]*0.6/100),0)) [RL_Net1]
,sum([AFTDS_CRANEWT_Tare])[AFTDS_CRANEWT_Tare]
,sum([AFTDS_CRANEWT_Gross]) [AFTDS_CRANEWT_Gross]
,sum([AFTDS_CRANEWT_Net])[AFTDS_CRANEWT_Net]
,sum([DS_LOSS_wt]) [DS_LOSS_wt]
FROM [Level3_KKC].[dbo].[HM_BALANCE]
Where [RL_WT_TIME]>='".$params['dateStart']."' and [RL_WT_TIME] <='".$params['dateEnd']."'";
select($query);
}
public function getData_HMCarReport_AVG($params)
{
$query = "
SELECT
avg([RL_Tare]) [RL_Tare]
,avg([RL_Gross])[RL_Gross]
,avg([RL_Net]) [RL_Net]
,avg(round([RL_Net]-([RL_Net]*0.6/100),0)) [RL_Net1]
,avg([AFTDS_CRANEWT_Tare])[AFTDS_CRANEWT_Tare]
,avg([AFTDS_CRANEWT_Gross]) [AFTDS_CRANEWT_Gross]
,avg([AFTDS_CRANEWT_Net])[AFTDS_CRANEWT_Net]
,avg([DS_LOSS_wt]) [DS_LOSS_wt]
FROM [Level3_KKC].[dbo].[HM_BALANCE]
Where [RL_WT_TIME]>='".$params['dateStart']."' and [RL_WT_TIME] <='".$params['dateEnd']."'";
select($query);
}
}

15
modules/HM_DC/HM_DC.php Normal file
View File

@@ -0,0 +1,15 @@
<?php
namespace API;
trait HM_DC
{
public function getData($params)
{
$d=1;
$query = "SELECT
*
FROM [Level3_KKC].[dbo].[HM_DC] WHERE [Date] BETWEEN '".$params['dateStart']."' AND '".$params['dateEnd']."'";
select_ru($query);
}
}

BIN
modules/KKC.rar Normal file

Binary file not shown.

50
modules/KKC/app.php Normal file
View File

@@ -0,0 +1,50 @@
<?php
namespace API;
trait app
{
public function appUser($params)
{
//WHERE [ip]='".$_SERVER['REMOTE_ADDR']."'
$query = "SELECT TOP 1 [id]
,[ip]
,[user_desc]
,[isAdmin]
,[isBan]
FROM [SITE].[dbo].[kkc_users]
WHERE [ip]='".$_SERVER['REMOTE_ADDR']."'
AND isBan <> 1";
select($query);
}
public function appHeadersById($params)
{
if ($params['isAdmin']) {
$query = "SELECT *
FROM [SITE].[dbo].[kkc_headers]
ORDER BY id";
} else {
$query = "SELECT * FROM [SITE].[dbo].[get_headers_by_user_id] ('".$params['id_user']."')";
}
select($query);
}
public function appAllSubheaders($params)
{
$query = "SELECT *
FROM [SITE].[dbo].[kkc_headers]
WHERE isHeader is not null
and idSubHeader is null
";
select($query);
}
public function appVisits($params)
{
$query = "SELECT count([isVisit]) countVisits
FROM [SITE].[dbo].[kkc_stat]
where [isVisit]=1";
select($query);
}
}

300
modules/KKC/dashboard.php Normal file
View File

@@ -0,0 +1,300 @@
<?php
namespace API;
trait dashboard
{
////////////////////////////STAT/////////////////////////////////////////
public function dashboardStat($params)
{
$query = "SELECT
convert(varchar, date, 104)+' '+convert(varchar, cast(date as datetime),108) as date
,ip
,user_desc
,title
,path
FROM [SITE].[dbo].[kkc_stat] s
INNER JOIN [SITE].[dbo].[kkc_users] u
ON s.id_user=u.id
where [isVisit] is null
and date>='".$params['dateStart']."' and date <='".$params['dateEnd']." 23:59:59'
order by date desc";
select($query);
}
public function dashboardStatCounts($params)
{
$query = "SELECT
count(id) as visit_counts
FROM [SITE].[dbo].[kkc_stat]
where [isVisit]=1
and DATEDIFF(day, date, GETDATE()) = 0
union all
SELECT
count(id) as visit_counts
FROM [SITE].[dbo].[kkc_stat]
where [isVisit]=1
and DATEDIFF(day, date, GETDATE()) = 1
union all
SELECT
count(id) as visit_counts
FROM [SITE].[dbo].[kkc_stat]
where [isVisit]=1
and DATEDIFF(day, date, GETDATE()) <= 7
union all
SELECT
count(id) as visit_counts
FROM [SITE].[dbo].[kkc_stat]
where [isVisit]=1
and DATEDIFF(month, date, GETDATE()) = 0
union all
SELECT
count(id) as visit_counts
FROM [SITE].[dbo].[kkc_stat]
where [isVisit]=1
and DATEDIFF(month, date, GETDATE()) = 1
union all
SELECT
count(id) as visit_counts
FROM [SITE].[dbo].[kkc_stat]
where [isVisit]=1";
select($query);
}
////////////////////////////ITEMS/////////////////////////////////////////
public function dashboardItemsAllHeaders($params)
{
$query = "SELECT *
FROM [SITE].[dbo].[kkc_headers]
ORDER BY id";
select($query);
}
public function dashboardItemsAdd($params)
{
$convName = iconv('UTF-8', 'windows-1251', $params['data']['name']);
global $conn;
$query = "SET NOCOUNT ON
DECLARE @insert_id int
INSERT INTO [SITE].[dbo].[kkc_headers]
VALUES(".$params['data']['idSubHeader'].",
".$params['data']['parent'].",
'$convName',
'".$params['data']['path']."',
'".$params['data']['pathFrame']."',
".$params['data']['isFrame'].",
".$params['data']['isHeader'].")
SELECT SCOPE_IDENTITY() as insert_id;
SET @insert_id=(SELECT SCOPE_IDENTITY())";
$result = sqlsrv_query($conn, $query);
sqlsrv_fetch($result);
if ($params['data']['isFrame']===1) {
$id_insert = sqlsrv_get_field($result, 0);
$query = "UPDATE [SITE].[dbo].[kkc_headers]
SET path='".$params['data']['path']."'+'$id_insert'
WHERE id=$id_insert";
$result = sqlsrv_query($conn, $query);
sqlsrv_fetch($result);
}
}
public function dashboardItemsEdit($params)
{
$convName = iconv('UTF-8', 'windows-1251', $params['data']['name']);
$query = "UPDATE [SITE].[dbo].[kkc_headers]
SET name='$convName',
path='".$params['data']['path']."',
pathFrame='".$params['data']['pathFrame']."'
WHERE id=".$params['data']['id']."";
update($query);
}
public function dashboardItemsDelete($params)
{
$query = "DELETE [SITE].[dbo].[kkc_groups_roles]
WHERE id_header in
(select id from [SITE].[dbo].[kkc_headers]
where idSubHeader=".$params['data']['id'].")
DELETE [SITE].[dbo].[kkc_groups_roles]
WHERE id_header=".$params['data']['id']."
DELETE [SITE].[dbo].[kkc_headers]
WHERE id=".$params['data']['id']."
OR idSubHeader=".$params['data']['id']."
";
delete($query);
}
////////////////////////////USERS/////////////////////////////////////////
public function dashboardUsers($params)
{
$query = "SELECT [id]
,[ip]
,[user_desc]
,[isAdmin]
,[isBan]
FROM [SITE].[dbo].[kkc_users]";
select($query);
}
public function dashboardUsersWithoutAdmin($params)
{
$query = "SELECT [id]
,[ip]
,[user_desc]
,[isAdmin]
,[isBan]
FROM [SITE].[dbo].[kkc_users]
WHERE isAdmin=0 and isBan=0";
select($query);
}
public function dashboardGroups($params)
{
$query = "SELECT
g.id,
g.name,
users.id as user_id,
users.user_desc as user_name,
users.ip as user_ip,
users.isAdmin as isAdmin
FROM [SITE].[dbo].[kkc_groups] g
inner join [SITE].[dbo].[kkc_users_groups] ug on
g.id=ug.group_id
inner join [SITE].[dbo].[kkc_users] users on
ug.user_id=users.id";
select($query);
}
public function dashboardUsersAdmin($params)
{
$query = "UPDATE [SITE].[dbo].[kkc_users]
SET isAdmin='".$params['data']['value']."'
WHERE id=".$params['data']['id']."";
update($query);
}
public function dashboardUsersBan($params)
{
$query = "UPDATE [SITE].[dbo].[kkc_users]
SET isBan='".$params['data']['value']."'
WHERE id=".$params['data']['id']."";
update($query);
}
public function dashboardUsersAdd($params)
{
$name = iconv('UTF-8', 'windows-1251', $params['data']['user_desc']);
$query = "INSERT INTO [SITE].[dbo].[kkc_users]
VALUES('".$params['data']['ip']."',
'$name',
0,0)";
insert($query);
}
public function dashboardUsersEdit($params)
{
$name = iconv('UTF-8', 'windows-1251', $params['data']['user_desc']);
$query = "UPDATE [SITE].[dbo].[kkc_users]
SET [user_desc]='$name',
ip='".$params['data']['ip']."'
WHERE id=".$params['data']['id']."";
update($query);
}
public function dashboardUsersDelete($params)
{
$query = "DELETE [SITE].[dbo].[kkc_users]
WHERE id=".$params['data']['id']."
DELETE [SITE].[dbo].[kkc_users_groups]
WHERE [user_id]=".$params['data']['id']."";
delete($query);
}
////////////////////////////////GROUPS//////////////////////////////////////////////////
public function dashboardGroupsAll($params)
{
$query = "SELECT g.id,
g.name,
count(ug.id) as group_count
FROM [SITE].[dbo].[kkc_groups] g
left join [SITE].[dbo].[kkc_users_groups] ug on
g.id=ug.group_id
left join [SITE].[dbo].[kkc_users] users on
ug.user_id=users.id
group by g.id, g.name";
select($query);
}
public function dashboardUsersGroupsAdd($params)
{
$name = iconv('UTF-8', 'windows-1251', $params['data']['name']);
$query = "INSERT INTO [SITE].[dbo].[kkc_groups]
VALUES('$name')";
insert($query);
}
public function dashboardUsersGroupsEdit($params)
{
$name = iconv('UTF-8', 'windows-1251', $params['data']['name']);
$query = "UPDATE [SITE].[dbo].[kkc_groups]
SET [name]='$name'
WHERE id=".$params['data']['id']."";
update($query);
}
public function dashboardUsersGroupsDelete($params)
{
$query = "DELETE [SITE].[dbo].[kkc_groups]
WHERE id=".$params['data']['id']."
DELETE [SITE].[dbo].[kkc_users_groups]
WHERE [group_id]=".$params['data']['id']."
DELETE [SITE].[dbo].[kkc_groups_roles]
WHERE [id_group]=".$params['data']['id']."
";
delete($query);
}
////////////////////////////////ROLES//////////////////////////////////////////////////
public function dashboardRoles($params)
{
$query = "SELECT [id]
,[id_group]
,[id_header]
FROM [SITE].[dbo].[kkc_groups_roles]";
select($query);
}
public function dashboardGroupsCheckUser($params)
{
$query = "INSERT INTO [SITE].[dbo].[kkc_users_groups]
VALUES(".$params['data']['userID'].",
".$params['data']['groupID'].")";
insert($query);
}
public function dashboardGroupsUnCheckUser($params)
{
$query = "DELETE [SITE].[dbo].[kkc_users_groups]
WHERE [user_id] =".$params['data']['userID']."
AND [group_id]=".$params['data']['groupID']."";
delete($query);
}
public function dashboardRolesDel($params)
{
$query = "DELETE [SITE].[dbo].[kkc_groups_roles]
WHERE [id_group] =".$params['data']['groupId']."";
delete($query);
}
public function dashboardRolesAdd($params)
{
foreach ($params['data']['values'] as $key => $value) {
$query = "INSERT INTO [SITE].[dbo].[kkc_groups_roles]
VALUES(".$params['data']['groupId'].",
".$value['id'].")";
insert($query);
}
}
}

256
modules/KKC/mega_report.php Normal file
View File

@@ -0,0 +1,256 @@
<?php
namespace API;
trait mega_report
{
public function getAllData($params)
{
$query = "SELECT
distinct
ctr.REPORT_ID ID
,HEAT_NUMBER
,DS_HM_LADLE_NUMBER [КЧ]
,HM_LADLE_CYCLE [Стойкость КЧ]
,DS_SHIFT_TEAM [Бригада ДС]
,FIRSTDS_Si [Si до ДС]
,FIRSTDS_S [S до ДС]
,FIRSTDS_P [P до ДС]
,FIRSTDS_Mn [Mn до ДС]
,HM_TEMP [T чугуна]
,HM_WEIGHT [Вес чугуна]
,convert(varchar, cast(CYCLE as smalldatetime),108) as [Цикл ДС]
,BRIGADA [№ бригады]
,STOIKOST [Стойкость конв.]
,MARKA [Марка стали]
,convert(varchar, cast(DT as datetime),104)+' '+convert(varchar, cast(DT as datetime),108) [Начало плавки]
,convert(varchar, cast(DTEnd as datetime),104)+' '+convert(varchar, cast(DTEnd as datetime),108) [Конец плавки]
,convert(varchar, cast(Cycl as smalldatetime),108) [Цикл плавки]
,BOF_HM_Weight [Вес чугуна]
,SCRAP_Weight [Вес лома]
,HEAT_Weight [Вес плавки]
,Si [Si чуг]
,CTR.S [S чуг]
,P [P чуг]
,Mn [Mn чуг]
,BOF_HM_Temp [T чугуна]
,C_p [C стали]
,S_p [S стали]
,P_p [P стали]
,Mn_p [Mn стали]
,HEAT_Temp [T стали]
,CTR.MgO [MgO шлака]
,CTR.FeO [FeO шлака]
,Bass [Основность шлака]
,LF_TREATMENTNO [№ обработки]
,LF_PLANTNO [Позиция]
,LF_LADLENO [№ сталь ковша]
,LF_MRESISTANCELADLE [Стойкость сталь ковша]
,LF_BRIGADANO [Бригада]
,LF_MTEMPERATUREBEFORE [Темп. приб]
,LF_LASTMEASTEMP [Темп. конечная]
,LF_HEATTIME [Время обраб.]
,LF_ARCONTIME [Время нагрева]
,LF_C
,LF_Mn
,LF_Si
,LF_S
,LF_P
,LF_Al
,LF_Nb
,LF_V
,LF_B
,LF_Cr
,LF_Ni
,LF_Cu
,lf.Al2O3 [Al2O3 шлак]
,lf.CaO [CaO шлак]
,lf.FeO [FeO шлак]
,lf.MgO [MgO шлак]
,lf.MnO [MnO шлак]
,lf.P2O5 [P2O5 шлак]
,lf.S [S шлак]
,lf.SiO2 [SiO2 шлак]
,CCM_ccm [Мнлз]
,CCM_TREATMENTNO [№ обр.]
,CCM_Br [Бригада]
,CCM_sech1 [Сечение Р1]
,CCM_sech2 [Сечение Р2]
,CCM_Cikl [Цикл]
,CCM_avgSpeedR1 [Скорость Р1 (сред)]
,CCM_avgSpeedR2 [Скорость Р2 (сред)]
,CCM_powder_str1 [Тип ШОС Р1]
,CCM_powder_str2 [Тип ШОС Р2]
,CCM_HEAT_IN_CAST [Серия/Плавка в серии]
,CCM_tund [Промковш/Плавка в промковше]
FROM Level3_KKC.dbo.BOF_CCM_TOTAL_REPORT CTR
left join (SELECT distinct lf1.[SLAGANALYSISID]
,lf1.[HEATNO]
,lf1.[ANALYSISDATE]
,lf1.[VALUEELEM1] as Al2O3
,lf1.[VALUEELEM2] as CaO
,lf1.[VALUEELEM3] as FeO
,lf1.[VALUEELEM4] as MgO
,lf1.[VALUEELEM5] as MnO
,lf1.[VALUEELEM6] as P2O5
,lf1.[VALUEELEM7] as S
,lf1.[VALUEELEM8] as SiO2
FROM [Level3_KKC].[dbo].[QLC_PRO_SLAGANALYSISHEADER_VD_L3] lf1
inner join [Level3_KKC].[dbo].[QLC_PRO_SLAGANALYSISHEADER_VD_L3] lf2 on
lf1.[SLAGANALYSISID]=lf2.[SLAGANALYSISID]
where lf1.[PLANTNO] IN (3,4)
and lf1.[SAMPLENO]=(select max([SAMPLENO]) from [Level3_KKC].[dbo].[QLC_PRO_SLAGANALYSISHEADER_VD_L3] where [HEATNO]=lf1.[HEATNO] and [PLANTNO] IN (3,4))) lf
on lf.HEATNO=HEAT_NUMBER
Where DT>='".$params['dateStart']."' and DT <='".$params['dateEnd']."'
--and BOF_AGGREGATE_ID = 1
order by HEAT_NUMBER,CCM_ccm,CCM_TREATMENTNO,LF_TREATMENTNO";
select($query);
}
public function getSteelData($params)
{
$query = "SELECT distinct
hm.[HEAT_NUMBER]
,[Name] [Установка]
,convert(varchar, cast(ANALYSISDATE as datetime),108) as 'Время'
,[Sample_number] [№]
,[value_1] Fe
,[value_2] P
,[value_3] S
,[value_4] Al
,[value_5] Cu
,[value_6] Cr
,[value_7] N
,[value_8] V
,[value_9] Nb
,[value_10] Ti
,[value_11] Sn
,[value_12] C
,[value_13] Mo
,[value_14] Si
,[value_15] W
,[value_16] Ni
,[value_17] Mn
,[value_18] Pb
,[value_19] Sb
,[value_20] B
,[value_21] Zr
,[value_22] Co
,[value_23] [As]
,[value_24] Zn
,[value_25] Ca
from(
(select distinct HEAT_NUMBER
FROM Level3_KKC.dbo.BOF_CCM_TOTAL_REPORT
Where DT>='".$params['dateStart']."' and DT <='".$params['dateEnd']."')) tr
left join [ANA_Operator].[dbo].[ANA_ALL_TRU] hm
on tr.HEAT_NUMBER=hm.Heat_number
where Sample_number<>0
and (Name IN ('LF', 'CCM1', 'CCM2', 'VD', 'BOF1', 'BOF2','AS1','AS2', 'DS', 'RL', 'ВАК'))
order by hm.HEAT_NUMBER, hm.Sample_number, Name";
select($query);
}
public function getHmData($params)
{
$query = "SELECT distinct
hm.[HEAT_NUMBER]
,[Name] [Установка]
,convert(varchar, cast(ANALYSISDATE as datetime),108) as 'Время'
,[Sample_number] [№]
,[value_1] C
,[value_2] Si
,[value_3] Mn
,[value_4] P
,[value_5] S
,[value_6] Cr
,[value_7] Mo
,[value_8] Ni
,[value_9] V
,[value_10] Al
,[value_11] Cu
,[value_12] Ti
,[value_13] Nb
,[value_14] W
,[value_15] [As]
,[value_16] Sn
,[value_17] Co
,[value_18] Pb
,[value_19] B
,[value_20] Sb
,[value_21] Bi
,[value_22] Zn
,[value_23] Ce
,[value_24] Fe
from(
(select distinct HEAT_NUMBER
FROM Level3_KKC.dbo.BOF_CCM_TOTAL_REPORT
Where DT>='".$params['dateStart']."' and DT <='".$params['dateEnd']."')) tr
left join [ANA_Operator].[dbo].[ANA_CHUGUN_ALL_TRU] hm
on tr.HEAT_NUMBER=hm.Heat_number
where Sample_number<>0
and (Name IN ('LF', 'CCM1', 'CCM2', 'VD', 'BOF1', 'BOF2', 'DS', 'RL', 'ВАК'))
order by hm.HEAT_NUMBER, hm.Sample_number, Name";
select($query);
}
public function getSlgData($params)
{
$query = "SELECT distinct
hm.[HEAT_NUMBER]
,[Name] [Установка]
,convert(varchar, cast(ANALYSISDATE as datetime),108) as 'Время'
,[Sample_number] [№]
,[value_1] Al2O3
,[value_2] CaO
,[value_3] MgO
,[value_4] MnO
,[value_5] P
,[value_6] S
,[value_7] SiO2
,[value_8] Fe
,[value_9] FeOp
,[value_10] Fe2O3p
,[value_11] P2O5p
,[value_12] [Основнось]
from(
(select distinct HEAT_NUMBER
FROM Level3_KKC.dbo.BOF_CCM_TOTAL_REPORT
Where DT>='".$params['dateStart']."' and DT <='".$params['dateEnd']."')) tr
left join
(select * from (select heatno as HEAT_NUMBER
, sampleno as Sample_number
,ANALYSISDATE, 'LF' as Name
,[VALUEELEM1] as value_1
,[VALUEELEM2] as value_2
,[VALUEELEM4] as value_3
,[VALUEELEM5] as value_4
,'' as value_5
,[VALUEELEM7] as value_6
,[VALUEELEM8] as value_7
,'' as value_8
,[VALUEELEM3] as value_9
,'' as value_10
,[VALUEELEM6] as value_11
,'' as value_12
from [Level3_KKC].[dbo].[QLC_PRO_SLAGANALYSISHEADER_VD_L3] where [PLANTNO] IN (3,4)
union all
SELECT Heat_number as HEAT_NUMBER
, Sample_number as Sample_number
,ANALYSISDATE as 'ДАТА', name
, value_1
, value_2
, value_3
, value_4
, value_5
, value_6
, value_7
, value_8
, value_9
, value_10
, value_11
, value_12
FROM [ANA_Operator].[dbo].[ANA_SLG_ALL_TRU])a) hm
on tr.HEAT_NUMBER=hm.Heat_number
where Sample_number<>0
order by hm.HEAT_NUMBER, hm.Sample_number, Name";
select($query);
}
}

View File

@@ -0,0 +1,14 @@
<?php
namespace API;
trait LadleUse
{
public function getData_LadleUse($params)
{
$query = "EXEC [Production].[dbo].[LADLE_USE]
@ds = '".$params['dateStart']."',
@de = '".$params['dateEnd']."'";
select_ru($query);
}
}

View File

@@ -0,0 +1,141 @@
<?php
header('Content-Type: text/html; charset=utf-8');
header('Access-Control-Allow-Origin: *');
header('Access-Control-Allow-Headers: *');
$input_name = 'file';
// Разрешенные расширения файлов.
$allow = array('xlsx', 'docx', 'xls', 'doc');
// Запрещенные расширения файлов.
$deny = array(
'phtml', 'php', 'php3', 'php4', 'php5', 'php6', 'php7', 'phps', 'cgi', 'pl', 'asp',
'aspx', 'shtml', 'shtm', 'htaccess', 'htpasswd', 'ini', 'log', 'sh', 'js', 'html',
'htm', 'css', 'sql', 'spl', 'scgi', 'fcgi'
);
// Директория куда будут загружаться файлы.
$path = __DIR__ . '/uploads/';
if (isset($_FILES[$input_name])) {
// Проверим директорию для загрузки.
if (!is_dir($path)) {
mkdir($path, 0777, true);
}
// Преобразуем массив $_FILES в удобный вид для перебора в foreach.
$files = array();
$diff = count($_FILES[$input_name]) - count($_FILES[$input_name], COUNT_RECURSIVE);
if ($diff == 0) {
$files = array($_FILES[$input_name]);
} else {
foreach($_FILES[$input_name] as $k => $l) {
foreach($l as $i => $v) {
$files[$i][$k] = $v;
}
}
}
foreach ($files as $file) {
$error = $success = '';
// Проверим на ошибки загрузки.
if (!empty($file['error']) || empty($file['tmp_name'])) {
switch (@$file['error']) {
case 1:
case 2: $error = 'Превышен размер загружаемого файла.'; break;
case 3: $error = 'Файл был получен только частично.'; break;
case 4: $error = 'Файл не был загружен.'; break;
case 6: $error = 'Файл не загружен - отсутствует временная директория.'; break;
case 7: $error = 'Не удалось записать файл на диск.'; break;
case 8: $error = 'PHP-расширение остановило загрузку файла.'; break;
case 9: $error = 'Файл не был загружен - директория не существует.'; break;
case 10: $error = 'Превышен максимально допустимый размер файла.'; break;
case 11: $error = 'Данный тип файла запрещен.'; break;
case 12: $error = 'Ошибка при копировании файла.'; break;
default: $error = 'Файл не был загружен - неизвестная ошибка.'; break;
}
} elseif ($file['tmp_name'] == 'none' || !is_uploaded_file($file['tmp_name'])) {
$error = 'Не удалось загрузить файл.';
} else {
// Оставляем в имени файла только буквы, цифры и некоторые символы.
$pattern = "[^a-zа-яё0-9,~!@#%^-_\$\?\(\)\{\}\[\]\.]";
$name = mb_eregi_replace($pattern, '-', $file['name']);
$name = mb_ereg_replace('[-]+', '-', $name);
// Т.к. есть проблема с кириллицей в названиях файлов (файлы становятся недоступны).
// Сделаем их транслит:
// $converter = array(
// 'а' => 'a', 'б' => 'b', 'в' => 'v', 'г' => 'g', 'д' => 'd', 'е' => 'e',
// 'ё' => 'e', 'ж' => 'zh', 'з' => 'z', 'и' => 'i', 'й' => 'y', 'к' => 'k',
// 'л' => 'l', 'м' => 'm', 'н' => 'n', 'о' => 'o', 'п' => 'p', 'р' => 'r',
// 'с' => 's', 'т' => 't', 'у' => 'u', 'ф' => 'f', 'х' => 'h', 'ц' => 'c',
// 'ч' => 'ch', 'ш' => 'sh', 'щ' => 'sch', 'ь' => '', 'ы' => 'y', 'ъ' => '',
// 'э' => 'e', 'ю' => 'yu', 'я' => 'ya',
// 'А' => 'A', 'Б' => 'B', 'В' => 'V', 'Г' => 'G', 'Д' => 'D', 'Е' => 'E',
// 'Ё' => 'E', 'Ж' => 'Zh', 'З' => 'Z', 'И' => 'I', 'Й' => 'Y', 'К' => 'K',
// 'Л' => 'L', 'М' => 'M', 'Н' => 'N', 'О' => 'O', 'П' => 'P', 'Р' => 'R',
// 'С' => 'S', 'Т' => 'T', 'У' => 'U', 'Ф' => 'F', 'Х' => 'H', 'Ц' => 'C',
// 'Ч' => 'Ch', 'Ш' => 'Sh', 'Щ' => 'Sch', 'Ь' => '', 'Ы' => 'Y', 'Ъ' => '',
// 'Э' => 'E', 'Ю' => 'Yu', 'Я' => 'Ya',
// );
// $name = strtr($name, $converter);
$parts = pathinfo($name);
if (empty($name) || empty($parts['extension'])) {
$error = 'Недопустимое тип файла';
} elseif (!empty($allow) && !in_array(strtolower($parts['extension']), $allow)) {
$error = 'Недопустимый тип файла';
} elseif (!empty($deny) && in_array(strtolower($parts['extension']), $deny)) {
$error = 'Недопустимый тип файла';
} else {
//Чтобы не затереть файл с таким же названием, добавим префикс.
// $i = 0;
// $prefix = '';
// while (is_file($path . $parts['filename'] . $prefix . '.' . $parts['extension'])) {
// $prefix = '(' . ++$i . ')';
// }
// $name = $parts['filename'] . $prefix . '.' . $parts['extension'];
date_default_timezone_set('Europe/Moscow');
$i = 0;
$prefix = '_(' . date("d-m-Y") . ')';
while (is_file($path . $parts['filename'] . $prefix . '.' . $parts['extension'])) {
$prefix = '_(' . date("d-m-Y") . ')(' . ++$i . ')';
}
$name = $parts['filename'] . $prefix . '.' . $parts['extension'];
// Перемещаем файл в директорию.
if (move_uploaded_file($file['tmp_name'], $path . $name)) {
// Далее можно сохранить название файла в БД и т.п.
$success = 'Файл «' . $name . '» успешно загружен.';
} else {
$error = 'Не удалось загрузить файл.';
var_dump(http_response_code(300));
}
}
}
// Выводим сообщение о результате загрузки.
if (!empty($success)) {
$post_data = array(
'success'=>$success,
'uploadIP'=>$_SERVER['REMOTE_ADDR'],
'fileName'=>$name,
'filePATH'=> $path . $name
);
echo json_encode(array('item' => $post_data), JSON_FORCE_OBJECT);
} else {
var_dump(http_response_code(300));
}
}
}
?>

View File

@@ -0,0 +1,81 @@
<?php
namespace API;
trait PRB_FileControl
{
public function insertFileInfo($params)
{
date_default_timezone_set('Europe/Moscow');
$time=date('H:i:s');
$name = iconv('UTF-8', 'windows-1251', $params['data']['item']['fileName']);
$filePATH = iconv('UTF-8', 'windows-1251', $params['data']['item']['filePATH']);
$query = "INSERT INTO [Production].[dbo].[PRB_FileControl] VALUES (
0,
'$name',
'$filePATH',
'".$params['data']['item']['uploadIP']."',
'".$params['data']['date']." $time')";
insert($query);
}
public function getFiles($params)
{
$query = "SELECT
[isCompleted]
,[file_name]
,[file_path]
,convert(varchar, [upload_date],104)+' - '+convert(varchar, [upload_date],108) as [Дата загрузки]
,[id]
FROM [Production].[dbo].[PRB_FileControl]
WHERE CAST([upload_date] as DATE)='".$params['data']."'
order by upload_date desc";
select($query);
}
public function setCompleted($params)
{
$query = "UPDATE [Production].[dbo].[PRB_FileControl]
SET isCompleted='".$params['data']['value']."'
WHERE id=".$params['data']['id']."";
update($query);
}
public function setHistory($params)
{
$query = "INSERT INTO [Production].[dbo].[PRB_FileLog] VALUES (
'".$params['id']."',
'".$_SERVER['REMOTE_ADDR']."',
GETDATE())";
insert($query);
}
public function getHistory($params)
{
$query = "SELECT
[upload_ip]+' ('+[DESCRIPT]+')' as IP_Author
,[download_ip]+' ('+[DESCRIPT]+')'as IP_Client
,convert(varchar, [download_date],104)+' - '+convert(varchar, [download_date],108) as download_date
FROM [Production].[dbo].[PRB_FileLog] fl
inner join [Production].[dbo].[PRB_FileControl] fc
on fl.file_id=fc.id
left join [SITE].[dbo].[Police_IP] ip
on fl.download_ip=ip.IP_ADDR
WHERE CAST([download_date] as DATE)='".$params['data']['date']."'
and file_id='".$params['data']['id']."'
order by download_date desc";
select($query);
}
public function deleteData($params)
{
$query = "DELETE [Production].[dbo].[PRB_FileControl]
WHERE id=".$params['data']['id']."";
delete($query);
$query = "DELETE [Production].[dbo].[PRB_FileLog]
WHERE file_id=".$params['data']['id']."";
delete($query);
$path = __DIR__ . '/uploads/';
$input_name=$params['data']['name'];
$f=$path.'/'.$input_name;
if (file_exists($f)) {
unlink($f);
}
}
}

View File

@@ -0,0 +1,14 @@
<?php
namespace API;
trait Pasport_KRO
{
public function getData_Pasport_KRO($params)
{
$query = "EXEC [Production].[dbo].[PASPORT_KRO]
@ds = '".$params['dateStart']."',
@de = '".$params['dateEnd']."'";
select_ru($query);
}
}

View File

@@ -0,0 +1,14 @@
<?php
namespace API;
trait LadleUse
{
public function getData_crewAggregateWeight($params)
{
$query = "EXEC [Level3_KKC].[dbo].[crewAggregateWeight]
@bd = '".$params['dateStart']."',
@ed = '".$params['dateEnd']."'";
select_ru($query);
}
}

View File

@@ -0,0 +1,57 @@
<?php
namespace API;
trait prohodnaya
{
public function get_services()
{
$query = "SELECT distinct[SERVICE], [ID_SERVICE]
FROM [eTabel].[dbo].[LIST_OF_WORKERS_TODAY]
order by [SERVICE]";
select($query);
}
public function get_departments()
{
$query = "SELECT distinct[DEPARTMENT], [ID_SERVICE], [ID_DEPARTMENT]
FROM [eTabel].[dbo].[LIST_OF_WORKERS_TODAY]
order by [DEPARTMENT]";
select($query);
}
public function get_crews()
{
$query = "SELECT distinct crew_desc.CREW as CREW_DESC, crew.ID_DEPARTMENT, crew.CREW, crew.SERVICE
FROM [eTabel].[dbo].[LIST_OF_WORKERS_TODAY] crew
inner join [eTabel].[dbo].[CREWS_DESC] crew_desc
on crew.CREW=crew_desc.ID_CREW
order by crew_desc.CREW";
select($query);
}
public function get_persons($params)
{
$query = "SELECT
DATE,
TAB,
FIO,
convert(varchar, cast(DATE_IN as smalldatetime),108) as DATE_IN,
convert(varchar, cast(DATE_OUT as smalldatetime),108) as DATE_OUT,
NAME_IN,
NAME_OUT,
crew_desc.CREW,
crew.CREW as ID_CREW,
SERVICE,
DEPARTMENT,
SHIFT,
SHEDULE
FROM [eTabel].[dbo].[IN_OUT_BY_DATE_TABLE] (
'".$params['date']."'
,'".$params['date']."') crew
inner join [eTabel].[dbo].[CREWS_DESC] crew_desc
on crew.CREW=crew_desc.ID_CREW
order by SERVICE, DEPARTMENT, CREW";
select($query);
}
}

52
modules/stat/stat.php Normal file
View File

@@ -0,0 +1,52 @@
<?php
namespace API;
trait stat
{
public function statAdd($params)
{
$query = "INSERT INTO [SITE].[dbo].[app_hub_stat] VALUES (
'".$params['data']."',
'".$_SERVER['REMOTE_ADDR']."'
,GETDATE())";
insert($query);
}
public function statGet($params)
{
$query = "
select
a.[project_name]
,count(a.[project_name]) as project_count
,convert(VARCHAR(10),b.[last_date],104) as last_date
FROM [SITE].[dbo].[app_hub_stat] a
left join (
SELECT project_name, max([last_date]) last_date FROM [SITE].[dbo].[app_hub_stat]
group by project_name
) b on b.project_name=a.project_name
group by a.[project_name], b.[last_date]
order by b.[last_date] desc
";
select($query);
}
public function statGetInfo($params)
{
$w=1;
$query = "
SELECT
--[project_name]
pip.DESCRIPT ip_desc
,[ip]
--,last_date
,convert(varchar, cast([last_date] as datetime),104)+' '+convert(varchar, cast([last_date] as datetime),108) date
--,convert(VARCHAR(10),[last_date],104)+' '+convert(VARCHAR(10),[last_date],108) as last_date
FROM [SITE].[dbo].[app_hub_stat] ahs
left join [SITE].[dbo].[Police_IP] pip
on ahs.ip=pip.ip_addr
where [project_name]='".$params['data']."'
order by last_date desc";
select($query);
}
}

View File

@@ -0,0 +1,36 @@
<?php
namespace API;
trait tundishSample
{
public function getDataHeats($params)
{
$query = "SELECT distinct
[HEAT_NAME]
,convert(varchar, [OPEN_TIME], 104) +' '+convert(varchar, [OPEN_TIME], 108) as OPEN_TIME
,convert(varchar, [CLOSE_TIME], 104) +' '+convert(varchar, [CLOSE_TIME], 108) as CLOSE_TIME
FROM [Level3_KKC].[dbo].[HEAT_CCM1_L3]
-- left join [Pasport_CCM].[dbo].[OPC_T_Tundish_sample_VALUES] ts
-- on [OPEN_TIME]<=ts.datetime and CLOSE_TIME>=ts.datetime
where CAST([CLOSE_TIME] as DATE) between'".$params['dateStart']."' and '".$params['dateEnd']."'
order by [OPEN_TIME] desc, [CLOSE_TIME] desc";
select($query);
}
public function getDataValues($params)
{
$query = "SELECT distinct
[HEAT_NAME]
,[button_all]
,[opc_T_sample_value]
,[count]
,convert(varchar, [datetime], 104) +' '+convert(varchar, [datetime], 108) as [datetime]
FROM [Level3_KKC].[dbo].[HEAT_CCM1_L3] ccm
inner join [Pasport_CCM].[dbo].[OPC_T_Tundish_sample_VALUES] ts
on [OPEN_TIME]<=ts.datetime and CLOSE_TIME>=ts.datetime
where CAST([CLOSE_TIME] as DATE) between'".$params['dateStart']."' and '".$params['dateEnd']."'
order by [datetime] desc";
select($query);
}
}

View File

@@ -0,0 +1,17 @@
<?php
namespace API;
trait weatherAvg
{
public function getData($params)
{
$query = "SELECT
round(avg([AirTemp_DegC]),2) as value
,convert(varchar, dt, 104) as dt
FROM [ASUTP].[dbo].[Weather_Status]
WHERE CAST(dt as DATE) BETWEEN '".$params['dateStart']."' AND '".$params['dateEnd']."'
group by convert(varchar, dt, 104)";
select($query);
}
}