Ejemplo n.º 1
0
        public float getLastData(Model.DjFlowInfo pressInfo)
        {
            using (OracleConnection conn = new OracleConnection(OracleHelper.ConnectionStringOrderDistributedTransaction))
            {
                String SQL = " SELECT INSDATA " +
                             " FROM " +
                             " (SELECT * " +
                             " FROM AD_DJ_FLOW " +
                             " WHERE DEVCODE = :devCode " +
                             " and UPTIME < :uptime " +
                             " order by UPTIME desc) " +
                             " where rownum=1 ";

                OracleParameter[] oraParams = new OracleParameter[] {
                    new OracleParameter(":devCode",pressInfo.DEVID),
                    new OracleParameter(":uptime",pressInfo.UPTIME)
                };
                DataTable dt = OracleHelper.ExecuteDataset(conn,CommandType.Text,SQL,oraParams).Tables[0];
                if (dt.Rows.Count > 0)
                {
                    float lastData = float.Parse(dt.Rows[0]["INSDATA"].ToString());
                    return(lastData);
                }
            }
            return(-1);
        }
Ejemplo n.º 2
0
        private AlarmRecordInfo getAlarmRecord(AlarmRuleInfo alarmRuleInfo, Model.DjFlowInfo pressInfo)
        {
            if (null != alarmRuleInfo)
            {
                float   curValue  = float.Parse(pressInfo.INSDATA);
                IDevice deviceDal = SensorHub.DALFactory.Device.Create();
                IDjFlow pressDal  = SensorHub.DALFactory.DjFlow.Create();

                AlarmRecordInfo alarmRecordInfo = new AlarmRecordInfo();
                alarmRecordInfo.ACTIVE           = true;
                alarmRecordInfo.DEVICE_CODE      = pressInfo.DEVID;
                alarmRecordInfo.DEVICE_ID        = alarmRuleInfo.DeviceId;
                alarmRecordInfo.DEVICE_TYPE_NAME = deviceDal.getDevTypeByCode(pressInfo.DEVID);
                alarmRecordInfo.ITEMNAME         = "流量值";
                alarmRecordInfo.ITEMVALUE        = curValue.ToString();
                alarmRecordInfo.MESSAGE_STATUS   = 0;
                alarmRecordInfo.RECORDCODE       = "";
                alarmRecordInfo.RECORDDATE       = System.DateTime.Now;

                if (alarmRuleInfo.HighValue != 0 && curValue > alarmRuleInfo.HighValue)
                {
                    alarmRecordInfo.MESSAGE = "流量超限";
                    return(alarmRecordInfo);
                }

                if (alarmRuleInfo.Saltation != 0)
                {
                    float lastData = pressDal.getLastData(pressInfo);
                    if (-1 != lastData && Math.Abs(curValue - lastData) > alarmRuleInfo.Saltation)
                    {
                        alarmRecordInfo.MESSAGE = "流量突变";
                        // return alarmRecordInfo;
                        return(null);
                    }
                }
            }
            return(null);
        }