示例#1
0
        public void UpdateDisplayResultHistory(string strCellID)
        {
            var pDocument   = CDocument.GetDocument;
            var pFormCommon = CFormCommon.GetFormCommon;

            do
            {
                string strQuery = null;
                // History Align
                CManagerTable objManagerTableHistoryAlign = pDocument.m_objProcessDatabase.m_objProcessDatabaseHistory.m_objManagerTableHistoryAlign;

                try {
                    strQuery  = string.Format("select * from {0} ", objManagerTableHistoryAlign.HLGetTableName());
                    strQuery += string.Format("where {0} = '{1}'",
                                              objManagerTableHistoryAlign.HLGetTableSchemaName()[( int )CDatabaseDefine.enumHistoryAlign.CELL_ID],
                                              strCellID);


                    DataTable objDataTable = new DataTable();
                    pDocument.m_objProcessDatabase.m_objProcessDatabaseHistory.m_objSQLite.HLReload(strQuery, ref objDataTable);
                    DataRow[] objDataRow = objDataTable.Select("", objManagerTableHistoryAlign.HLGetTableSchemaName()[( int )CDatabaseDefine.enumHistoryAlign.CELL_ID] + " " + CDatabaseDefine.DEF_ASC);

                    for (int iLoopCount = 0; iLoopCount < objDataRow.Length; iLoopCount++)
                    {
                        UpdateDisplay(objDataRow[iLoopCount]);
                    }
                } catch (Exception ex) {
                    Trace.WriteLine(ex.Message);
                }
            } while(false);
        }
        //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
        //생성 :
        //추가 :
        //목적 : 히스토리 삭제 쿼리 날려줌
        //설명 :
        //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
        private void SetDeleteHistory(CManagerTable objManagerTable, int iIndex, int iDeletePeriod)
        {
            // 금일을 기준으로 특정일을 계산해야함
            DateTime objDate  = DateTime.Today;
            string   strQuery = string.Format("delete from {0} where {1} < datetime('{2}')",
                                              objManagerTable.HLGetTableName(), objManagerTable.HLGetTableSchemaName()[iIndex],
                                              string.Format("{0} 23:59:59", objDate.AddDays(-1 * Math.Abs(iDeletePeriod)).ToString(CDatabaseDefine.DEF_DATE_FORMAT)));

            m_objSQLite.HLExecute(strQuery);
        }
        //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
        //생성 :
        //추가 :
        //목적 : 얼라인 히스토리 삽입
        //설명 :
        //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
        public override void SetInsertHistoryAlign(object objData)
        {
            CDatabaseSendMessage.CHistoryAlign obj = objData as CDatabaseSendMessage.CHistoryAlign;

            var           pDocument            = CDocument.GetDocument;
            string        strQuery             = null;
            string        strDate              = DateTime.Now.ToString(CDatabaseDefine.DEF_DATE_TIME_FORMAT);
            CManagerTable objManagerTableAlign = pDocument.m_objProcessDatabase.m_objProcessDatabaseHistory.m_objManagerTableHistoryAlign;

            lock (pDocument.m_objProcessDatabase.m_objProcessDatabaseHistory.m_objSQLite) {
                try {
                    // 트랜잭션 시작
                    var objTransaction = pDocument.m_objProcessDatabase.m_objProcessDatabaseHistory.m_objSQLite.HLBeginTransaction();
                    // Align Data
                    strQuery  = string.Format("insert into {0} values (", objManagerTableAlign.HLGetTableName());
                    strQuery += string.Format("'{0}_{1}',", strDate, obj.m_objData.strCellID.ToString()); // inner id
                    strQuery += string.Format("'{0}',", strDate);                                         // date
                    strQuery += string.Format("'{0}',", obj.m_objData.strCellID);                         // cell id
                    strQuery += string.Format("{0:D},", obj.m_objData.iPosition);                         // position
                    strQuery += string.Format("{0:D},", obj.m_objData.iTactTime);                         // tact time
                    strQuery += string.Format("'{0}',", obj.m_objData.strResult);                         // Result
                    strQuery += string.Format("'{0}',", obj.m_objData.strNgType);                         // Ng Type
                    for (int iLoopCount = 0; iLoopCount < CDefine.DEF_MAX_COUNT_CROP_REGION; iLoopCount++)
                    {
                        // VIDI 결과
                        strQuery += string.Format("'{0:F2}',", obj.m_objData.dVidiScore[iLoopCount]);
                        strQuery += string.Format("'{0}',", obj.m_objData.strVidiResult[iLoopCount]);
                    }

                    for (int iLoopCount = 0; iLoopCount < CDefine.DEF_MAX_COUNT_CROP_REGION; iLoopCount++)
                    {
                        //치수측정
                        strQuery += string.Format("'{0:F2}',", obj.m_objData.dMeasureWidth[iLoopCount]);
                        strQuery += string.Format("'{0:F2}',", obj.m_objData.dMeasureHeight[iLoopCount]);
                        strQuery += string.Format("'{0}',", obj.m_objData.strMeasureResult[iLoopCount]);
                    }

                    for (int iLoopCount = 0; iLoopCount < CDefine.DEF_MAX_COUNT_CROP_REGION; iLoopCount++)
                    {
                        //치수측정
                        strQuery += string.Format("'{0:F2}',", obj.m_objData.str3dHeightResult[iLoopCount]);
                    }

                    for (int iLoopCount = 0; iLoopCount < CDefine.DEF_MAX_COUNT_CROP_REGION; iLoopCount++)
                    {
                        //치수측정
                        strQuery += string.Format("'{0:F2}',", obj.m_objData.dMeasureStartX[iLoopCount]);
                        strQuery += string.Format("'{0:F2}',", obj.m_objData.dMeasureStartY[iLoopCount]);
                        strQuery += string.Format("'{0:F2}',", obj.m_objData.dMeasureEndX[iLoopCount]);
                        strQuery += string.Format("'{0:F2}',", obj.m_objData.dMeasureEndY[iLoopCount]);
                    }

                    strQuery += string.Format("'{0}',", obj.m_objData.iMeasureLineFindCount);
                    strQuery += string.Format("'{0:F2}',", obj.m_objData.dPatternPositionX);
                    strQuery += string.Format("'{0:F2}',", obj.m_objData.dPatternPositionY);

                    // 마지막 구문
                    strQuery += string.Format("'{0}')", obj.m_objData.strImagePath);


                    pDocument.m_objProcessDatabase.m_objProcessDatabaseHistory.m_objSQLite.HLExecute(strQuery);
                    // 커밋
                    pDocument.m_objProcessDatabase.m_objProcessDatabaseHistory.m_objSQLite.HLCommit(objTransaction);
                }
                catch (Exception ex) {
                    Trace.WriteLine(ex.Message);
                }
            }
        }