2023년 1월 10일 화요일

MSSQL - INDEX 재 정리


SQL Server Management Studio 사용하여 인덱스 유지 관리


인덱스를 다시 구성하거나 다시 작성하려면


1. 개체 탐색기에서 인덱스를 다시 구성할 테이블이 포함된 데이터베이스를 확장합니다.

2. 테이블 폴더를 확장합니다.

3. 인덱스를 다시 구성할 테이블을 확장합니다.

4. 인덱스 폴더를 확장합니다.

5. 다시 구성할 인덱스를 마우스 오른쪽 단추로 클릭하고 다시 구성을 선택합니다.

6. 인덱스 다시 구성 대화 상자에서 다시 구성할 인덱스 표에 올바른 인덱스가 있는지 확인한 다음 확인을 클릭합니다.

7. 큰 개체 열 데이터 압축 확인란을 선택하여 LOB(Large Object) 데이터가 포함된 모든 페이지도 압축되도록 지정합니다.

8. 확인.


테이블의 모든 인덱스를 다시 구성하려면


1. 개체 탐색기에서 인덱스를 다시 구성할 테이블이 포함된 데이터베이스를 확장합니다.

2. 테이블 폴더를 확장합니다.

3. 인덱스를 다시 구성할 테이블을 확장합니다.

4. 인덱스 폴더를 마우스 오른쪽 단추로 클릭하고 모두 다시 구성을 선택합니다.

5. 인덱스 다시 구성 대화 상자에서 다시 구성할 인덱스에 올바른 인덱스가 있는지 확인합니다. 다시 구성할 인덱스 표에서 인덱스를 제거하려면 인덱스를 선택한 다음 Delete 키를 누릅니다.

6. 큰 개체 열 데이터 압축 확인란을 선택하여 LOB(Large Object) 데이터가 포함된 모든 페이지도 압축되도록 지정합니다.

7. 확인.





[1] 특정 인덱스를 다시 구성하려면


ALTER INDEX IX_Employee_OrganizationalLevel_OrganizationalNode

    ON HumanResources.Employee

    REORGANIZE;



[2] 테이블의 모든 인덱스를 다시 구성하려면 (인덱스를 다시 작성하는 것보다 리소스가 덜 사용됩니다. 기본 인덱스 유지 관리 방법.)


ALTER INDEX ALL ON HumanResources.Employee 

REORGANIZE;



[3] 인덱스를 다시 작성하려면 (인덱스가 삭제된 다음 다시 생성됩니다. 작업 시 잠금 및 DB성능 저하.)


ALTER INDEX PK_Employee_BusinessEntityID ON HumanResources.Employee 

REBUILD;



[4] 테이블에서 모든 인덱스를 다시 작성하려면 (서비스 내리고 진행해야 함. 데이터의 크기에 따라 시간이 오래 걸릴 수 있음.)


ALTER INDEX ALL ON Production.Product

REBUILD WITH (FILLFACTOR = 80, SORT_IN_TEMPDB = ON,

              STATISTICS_NORECOMPUTE = ON);



2023년 1월 4일 수요일

C# - WebClient (예문)


[예1]
            try
            {
                string uri = ChatbotCommon.ChatbotAPIUrl + "/api/chat/";
                requestJson = JsonConvert.SerializeObject(chatbotRequest);
                WebClient webClient = new WebClient();
                webClient.Headers[HttpRequestHeader.ContentType] = "application/json";
                webClient.Headers.Add("Session", GetChatBotSessionID());
                webClient.Encoding = UTF8Encoding.UTF8;
                responseJSON = webClient.UploadString(uri, requestJson);
                resObj = JsonConvert.DeserializeObject<ChatbotResponse>(responseJSON);
                var bizChatbot = BizFactory.GetInstance<BizChatbot>();
                // 미소몰 챗봇 로그 저장
                bizChatbot.SetMisomallChatbotLog(MisoMember.MemIdx, resObj);
            }
            catch
            {
                //어떠한 상황이건 API 결과가 에러일 경우 아래 메시지 출력
                resObj = new ChatbotResponse();
                resObj.QueryResult.Intent.Name = "ERROR";
                resObj.QueryResult.Answer.Type = "TEXT";
                resObj.QueryResult.Answer.Value = "잠시 후 다시 이용해 주세요.";
            }
            finally
            {
                // 로그 저장
            }


[예2]
            try
            {
                string uri = SearchCommons.SearchAPIDomainPath + "/extensions/totalSearch/";
                string requestJSON = JsonConvert.SerializeObject(searchInput);

                using (WebClient webClient = new WebClient())
                {
                    webClient.Headers[HttpRequestHeader.ContentType] = "application/json";
                    webClient.Encoding = UTF8Encoding.UTF8;

                    responseJSON = webClient.UploadString(uri, requestJSON);  // POST
                    //responseJSON = webClient.DownloadString(uri + "?" + data);  // GET
                }
                searchResult = JsonConvert.DeserializeObject<SearchResult>(responseJSON);
            }
            catch (Exception e)
            {
                throw e;
            }
            finally
            {
            }


[예3 - SecurityProtocol]
            try
            {
                ServicePointManager.SecurityProtocol = SecurityProtocolType.Ssl3 | SecurityProtocolType.Tls | SecurityProtocolType.Tls11 | SecurityProtocolType.Tls12;

                string uri = "~/api/o-purchase/~";
                string requestJSON = JsonConvert.SerializeObject(request);
                using (WebClient webClient = new WebClient())
                {
                    webClient.Encoding = Encoding.UTF8;
                    webClient.Headers[HttpRequestHeader.ContentType] = "application/json";
                    responseJSON = webClient.UploadString(uri, requestJSON);
                }
                Result = JsonConvert.DeserializeObject<Reponse>(responseJSON);
            }
            catch (Exception e)
            {
                throw e;
            }
            finally
            {
            }


[예4]
            try
            {
                string uri = "~/api/drug/info~";
                string EncKimsID = GetBase64(KimsID + ':');
                string requestJSON = JsonConvert.SerializeObject(kimsDrugRequest);

                using (WebClient webClient = new WebClient())
                {
                    webClient.Encoding = UTF8Encoding.UTF8;
                    webClient.Headers[HttpRequestHeader.ContentType] = "application/json";
                    webClient.Headers[HttpRequestHeader.Authorization] = "Basic " + EncKimsID;

                    responseJSON = webClient.UploadString(uri, requestJSON);  // POST
                }
                kimsDrugResponse = JsonConvert.DeserializeObject<KimsDrugResponse>(responseJSON);
            }
            catch (Exception e)
            {
                throw e;
            }
            finally
            {
            }

 

C# - 이니시스 결제 Model (Moblie)


namespace Misomall.Model
{
    #region 승인결과
    public class InicisMobileResult
    {
        #region 공통
        /// <summary>
        /// 거래상태 (성공:00)
        /// </summary>
        [StringLength(4)]
        public string P_STATUS { get; set; }
        /// <summary>
        /// 거래번호
        /// </summary>
        [StringLength(40)]
        public string P_TID { get; set; }
        /// <summary>
        /// 지불수단
        /// </summary>
        [StringLength(10)]
        public string P_TYPE { get; set; }
        /// <summary>
        /// 승인일자 (YYYYmmddHHmmss)
        /// </summary>
        [StringLength(14)]
        public string P_AUTH_DT { get; set; }
        /// <summary>
        /// 상점아이디
        /// </summary>
        [StringLength(10)]
        public string P_MID { get; set; }
        /// <summary>
        /// 상점 주문번호
        /// </summary>
        [StringLength(100)]
        public string P_OID { get; set; }
        /// <summary>
        /// 거래금액
        /// </summary>
        [StringLength(8)]
        public string P_AMT { get; set; }
        /// <summary>
        /// 주문자명
        /// </summary>
        [StringLength(30)]
        public string P_UNAME { get; set; }
        /// <summary>
        /// 가맹점 이름
        /// </summary>
        public string P_MNAME { get; set; }
        /// <summary>
        /// 메시지 1
        /// </summary>
        [StringLength(500)]
        public string P_RMESG1 { get; set; }
        /// <summary>
        /// 기타 주문정보 (주문정보에 입력한 값 반환)
        /// </summary>
        [StringLength(800)]
        public string P_NOTI { get; set; }
        /// <summary>
        /// 가맹점 전달 NOTI URL (거래요청 시 입력한 값을 그대로 반환합니다.)
        /// </summary>
        public string P_NOTEURL { get; set; }
        /// <summary>
        /// 가맹점 전달 NEXT URL (거래요청 시 입력한 값을 그대로 반환합니다.)
        /// </summary>
        public string P_NEXT_URL { get; set; }
        #endregion

        #region 가상계좌
        /// <summary>
        /// 입금할 계좌 번호
        /// </summary>
        [StringLength(20)]
        public string P_VACT_NUM { get; set; }
        /// <summary>
        /// 입금마감일자
        /// </summary>
        [StringLength(8)]
        public string P_VACT_DATE { get; set; }
        /// <summary>
        /// 입금마감시간
        /// </summary>
        [StringLength(6)]
        public string P_VACT_TIME { get; set; }
        /// <summary>
        /// 계좌주명
        /// </summary>
        public string P_VACT_NAME { get; set; }
        /// <summary>
        /// 은행코드
        /// </summary>
        [StringLength(2)]
        public string P_VACT_BANK_CODE { get; set; }
        #endregion

        #region 신용카드
        /// <summary>
        /// 발급사 코드
        /// </summary>
        [StringLength(2)]
        public string P_CARD_ISSUER_CODE { get; set; }
        /// <summary>
        /// 가맹점번호
        /// </summary>
        public string P_CARD_MEMBER_NUM { get; set; }
        /// <summary>
        /// 매입사 코드
        /// </summary>
        public string P_CARD_PURCHASE_CODE { get; set; }
        /// <summary>
        /// 부분취소 가능여부 (부분취소가능 : 1 , 부분취소불가능 :0)
        /// </summary>
        public string P_CARD_PRTC_CODE { get; set; }
        /// <summary>
        /// 무이자 할부여부 (0 : 일반, 1 : 무이자)
        /// </summary>
        public string P_CARD_INTEREST { get; set; }
        /// <summary>
        /// 체크카드 여부 (0 : 신용카드, 1 : 체크카드, 2 : 기프트카드)
        /// </summary>
        public string P_CARD_CHECKFLAG { get; set; }
        /// <summary>
        /// 메시지 2 (신용카드 할부 개월 수)
        /// </summary>
        [StringLength(500)]
        public string P_RMESG2 { get; set; }
        /// <summary>
        /// 카드코드
        /// </summary>
        public string P_FN_CD1 { get; set; }
        /// <summary>
        /// 승인번호 (신용카드거래에서만 사용합니다)
        /// </summary>
        [StringLength(30)]
        public string P_AUTH_NO { get; set; }
        /// <summary>
        /// VP 카드코드
        /// </summary>
        public string P_ISP_CARDCODE { get; set; }
        /// <summary>
        /// 결제카드한글명 (BC카드)
        /// </summary>
        public string P_FN_NM { get; set; }
        #endregion

        #region 신용카드 U 포인트
        /// <summary>
        /// 카드번호
        /// </summary>
        public string P_CARD_NUM { get; set; }
        #endregion

        #region 계좌이체
        /// <summary>
        /// 은행코드
        /// </summary>
        //public string P_FN_CD1 { get; set; }
        /// <summary>
        /// 결제은행한글명
        /// </summary>
        //public string P_FN_NM { get; set; }
        #endregion

        #region 휴대폰
        /// <summary>
        /// 휴대폰 통신사
        /// </summary>
        [StringLength(3)]
        public string P_HPP_CORP { get; set; }
        /// <summary>
        /// 결제 휴대폰 번호
        /// </summary>
        public string P_HPP_NUM { get; set; }
        #endregion

        #region 전자지갑
        /// <summary>
        /// 전자지갑 종류 (YPAY : 옐로페이, KWPY : 뱅크월렛)
        /// </summary>
        public string P_EWALLET_TYPE { get; set; }
        #endregion

        #region 앱연동 결제구분
        /// <summary>
        /// 앱연동여부 (P : 페이핀, K : 국민앱카드, C: 페이코, B: 삼성페이, L: LPAY, O: 카카오페이, G: SSGPAY)
        /// </summary>
        public string P_SRC_CODE { get; set; }
        #endregion

        #region 현금 영수증
        /// <summary>
        /// 처리상태 (220000 : 정상, 그 외 : 오류)
        /// </summary>
        public string P_CSHR_CODE { get; set; }
        /// <summary>
        /// 처리 메시지
        /// </summary>
        public string P_CSHR_MSG { get; set; }
        /// <summary>
        /// 현금영수증 총 금액 (총금액 = 공급가액+세금+봉사료)
        /// </summary>
        public string P_CSHR_AMT { get; set; }
        /// <summary>
        /// 공급가액
        /// </summary>
        public string P_CSHR_SUP_AMT { get; set; }
        /// <summary>
        /// 세금
        /// </summary>
        public string P_CSHR_TAX { get; set; }
        /// <summary>
        /// 봉사료
        /// </summary>
        public string P_CSHR_SRVC_AMT { get; set; }
        /// <summary>
        /// 용도구분 (0:소득공제용, 1:지출증빙용)
        /// </summary>
        public string P_CSHR_TYPE { get; set; }
        /// <summary>
        /// 발행시간
        /// </summary>
        public string P_CSHR_DT { get; set; }
        /// <summary>
        /// 발행번호 (가상계좌의 경우, 입금 완료 시, 생성되어 모바일 내 채번시에는 전달되지 않습니다.)
        /// </summary>
        public string P_CSHR_AUTH_NO { get; set; }
        #endregion

        #region 추가 사항 (웹표준 모듈 및 모바일 모듈에서 동일하게 사용하기 위해)
        /// <summary>
        /// 결제수단
        /// </summary>
        public string payMethod { get; set; }
        /// <summary>
        /// 승인일자 (YYYYMMDD)
        /// </summary>
        [StringLength(8)]
        public string applDate { get; set; }
        /// <summary>
        /// 승인시간 (hh24miss)
        /// </summary>
        [StringLength(6)]
        public string applTime { get; set; }
        #endregion
    }
     #endregion
}

C# - 이니시스 결제 Model (Web)


namespace Model
{
    #region 결제 요청
    /// <summary>
    /// 결제 요청
    /// </summary>
    public class InicisRequest
    {
        #region 기본 데이터 필드
        /// <summary>
        /// 버전 (1.0)
        /// (필수)
        /// </summary>
        [Required]
        [StringLength(20)]
        public string version { get; set; }
        /// <summary>
        /// 상점아이디 (테스트 아이디 INIpayTest)
        /// (필수)
        /// </summary>
        [Required]
        [StringLength(10)]
        public string mid { get; set; }
        /// <summary>
        /// 이니시스 주문번호 (예 INIpayTest_1335233672723)
        /// (필수)
        /// </summary>
        [Required]
        [StringLength(40)]
        public string oid { get; set; }
        /// <summary>
        /// 상품명
        /// (필수)
        /// </summary>
        [Required]
        [StringLength(40)]
        public string goodname { get; set; }
        /// <summary>
        /// 결제금액
        /// (필수)
        /// </summary>
        [Required]
        public int price { get; set; }
        /// <summary>
        /// 부가세
        /// </summary>
        public int tax { get; set; }
        /// <summary>
        /// 비과세
        /// </summary>
        public int taxfree { get; set; }
        /// <summary>
        /// 통화구분 (WON:한화,USD:달러)
        /// (필수)
        /// </summary>
        [Required]
        [StringLength(3)]
        public string currency { get; set; }
        /// <summary>
        /// 구매자명
        /// (필수)
        /// </summary>
        [Required]
        [StringLength(30)]
        public string buyername { get; set; }
        /// <summary>
        /// 구매자 Mobile번호 (010-2000-1234)
        /// (필수)
        /// </summary>
        [Required]
        [StringLength(20)]
        public string buyertel { get; set; }
        /// <summary>
        /// 구매자 Email (buyer@example.com)
        /// </summary>
        [StringLength(60)]
        public string buyeremail { get; set; }
        /// <summary>
        /// 보호자 Email (parent@example.com)
        /// </summary>
        [StringLength(60)]
        public string parentemail { get; set; }
        /// <summary>
        /// 타임스탬프 (제공라이브러로 생성가능)
        /// (필수)
        /// </summary>
        [Required]
        [StringLength(20)]
        public string timestamp { get; set; }
        /// <summary>
        /// signature (위변조 방지 SHA256 Hash 값)
        /// (필수)
        /// </summary>
        [Required]
        [StringLength(64)]
        public string signature { get; set; }
        /// <summary>
        /// 리턴 Url (인증결과수신Url)
        /// 결제창을 통해 인증완료된 결과를 수신받고 승인요청을 해서 결과를 표시할 페이지 URL
        /// (필수)
        /// </summary>
        [Required]
        public string returnUrl { get; set; }
        /// <summary>
        /// signkey에 대한 hash값
        /// (필수)
        /// </summary>
        [Required]
        public string mKey { get; set; }
        /// <summary>
        /// 요청결제수단
        /// 하나의 결제 수단만을 제공할 경우 사용함. 생략시 전체 결제 수단 표시
        /// (필수)
        /// </summary>
        [Required]
        public string gopaymethod { get; set; }
        /// <summary>
        /// 제공기간 (yyyyMMdd-yyyyMMdd : 시작일-종료일)
        /// 가맹점에서 판매상품에 대한 제공기한 설정
        /// </summary>
        public string offerPeriod { get; set; }
        /// <summary>
        /// 초기 표시 언어 (ko:한국어, en:영어)
        /// 결제창 표시 언어
        /// </summary>
        [StringLength(2)]
        public string languageView { get; set; }
        /// <summary>
        /// 결과 인코딩 (UTF-8, EUC-KR)
        /// </summary>
        [StringLength(5)]
        public string charset { get; set; }
        /// <summary>
        /// 결제창 표시방법 (overlay)
        /// </summary>
        public string payViewType { get; set; }
        /// <summary>
        /// 결제창 닫기처리 Url
        /// (필수)
        /// </summary>
        [Required]
        public string closeUrl { get; set; }
        /// <summary>
        /// 팝업처리 Url
        /// (필수)
        /// </summary>
        [Required]
        public string popupUrl { get; set; }
        /// <summary>
        /// 가맹점 데이터 (인증 성공시 가맹점으로 리턴)
        /// (예) a=A&b=B
        /// </summary>
        [StringLength(2000)]
        public string merchantData { get; set; }
        /// <summary>
        /// 결제수단별 추가 옵션값
        /// </summary>
        public string acceptmethod { get; set; }
        #endregion
        #region 신용카드 추가 데이터 필드 (선택)
        /// <summary>
        /// 할부 개월 
        /// “2:3:4”, “2:0”(개월수를 : 로 구분된 값)
        /// 일시불은 기본적을 표시, 생략시 일시불만 (* 5만원 이상시에만 동작)
        /// </summary>
        public string quotabase { get; set; }
        /// <summary>
        /// 가맹점 부담 무이자 할부설정
        /// “11-2:3:5:6,34-2:6”, “04-2:6”
        /// 카드사코드-할부개월:할부개월… 여러카드는 공백없이 ,로 구분 (* 5만원 이상시에만 동작 / 카드사 무이자와 무관)
        /// </summary>
        public string nointerest { get; set; }
        /// <summary>
        /// below1000 (1000원 이하 결제)
        /// mallpoint (몰포인트)
        /// ini_onlycardcode (결제 카드사 선택)
        /// CARDPOINT (카드포인트 사용유무)
        /// OCB (OK Cashbag 사용유무)
        /// SLIMQUOTA (부분무이자 설정)
        /// PAYPOPUP (인심클릭뷰 옵션)
        /// hidebar (프로그래스바 뷰 옵션)
        /// useescro (신에스크로 사용 여부)
        /// </summary>
        //public string acceptmethod { get; set; }
        #endregion
        #region 계좌이체 추가 데이터 필드 (선택)
        /// <summary>
        /// no_receipt (현금영수증 미발행)
        /// </summary>
        //public string acceptmethod { get; set; }
        #endregion
        #region 무통장 입금 추가 데이터 필드 (선택)
        /// <summary>
        /// 주민번호 설정 기능
        /// </summary>
        public string INIregno { get; set; }
        /// <summary>
        /// vbank (입금기한 및 입금시간)
        /// va_receipt (현금영수증 발급 UI 옵션)
        /// va_ckprice (주민번호 채번 시 금액 확인)
        /// </summary>
        //public string acceptmethod { get; set; }
        #endregion
        #region 전자지갑(뱅크월렛) 추가 데이터 필드 (선택)
        /// <summary>
        /// KWPY_TYPE (결제구분) (0:현금카드와 뱅크머니 모두, 1:현금카드만, 2:뱅크머니만)
        /// KWPY_VAT (부가세, 봉사료)
        //public string acceptmethod { get; set; }
        #endregion
        #region 빌링 추가 데이터 필드 (선택)
        /// <summary>
        /// BILLAUTH (빌링 결제 구분) (BILLAUTH(card))
        /// 신용카드 빌링 결제를 제공한다.
        //public string acceptmethod { get; set; }
        #endregion
    }
    #endregion

    #region 인증 결과 수신
    /// <summary>
    /// 인증 결과 수신
    /// </summary>
    public class InicisCertificationResult
    {
        /// <summary>
        /// 결과코드 (0000 : 정상, 기타 : 실패)
        /// </summary>
        [StringLength(10)]
        public string resultCode { get; set; }
        /// <summary>
        /// 결과메세지 (성공시 : OK, 실패시 : 기타 오류 메시지)
        /// </summary>
        [StringLength(100)]
        public string resultMsg { get; set; }
        /// <summary>
        /// 가맹점 ID
        /// </summary>
        [StringLength(10)]
        public string mid { get; set; }
        /// <summary>
        /// 가맹점 주문번호 (oid)
        /// </summary>
        [StringLength(40)]
        public string orderNumber { get; set; }
        /// <summary>
        /// 승인요청 (승인요청검증토큰)
        /// </summary>
        public string authToken { get; set; }
        /// <summary>
        /// 승인요청 Url
        /// 해당 URL로 HTTPS API Request(httpClient 통신) 승인 요청(POST)
        /// </summary>
        public string authUrl { get; set; }
        /// <summary>
        /// 망취소요청 Url
        /// </summary>
        public string netCancelUrl { get; set; }
        /// <summary>
        /// 인코딩 (가맹점에서 결제요청시 전달한 charset값 생략시 UTF-8)
        /// </summary>
        [StringLength(5)]
        public string charset { get; set; }
        /// <summary>
        /// 가맹점 데이터
        /// </summary>
        [StringLength(2000)]
        public string merchantData { get; set; }
    }
    #endregion

    #region 결제 승인 요청
    /// <summary>
    /// 결제 승인 요청
    /// </summary>
    public class InicisApprovalRequest
    {
        /// <summary>
        /// 상점아이디 (테스트 아이디 INIpayTest)
        /// (필수)
        /// </summary>
        [Required]
        [StringLength(10)]
        public string mid { get; set; }
        /// <summary>
        /// 승인요청 (승인요청검증토큰)
        /// (필수)
        /// </summary>
        [Required]
        public string authToken { get; set; }
        /// <summary>
        /// 결제금액
        /// (필수)
        /// </summary>
        [Required]
        public int price { get; set; }
        /// <summary>
        /// 타임스탬프 (제공라이브러로 생성가능)
        /// (필수)
        /// </summary>
        [Required]
        public int timestamp { get; set; }
        /// <summary>
        /// signature (위변조 방지 SHA256 Hash 값)
        /// (필수)
        /// </summary>
        [Required]
        [StringLength(64)]
        public string signature { get; set; }
        /// <summary>
        /// 인코딩 (결과 수신 charset)
        /// </summary>
        [StringLength(5)]
        public string charset { get; set; }
        /// <summary>
        /// 리턴 형식 (XML, JSON, NVP])
        /// XML : <result>내의 XML 결과 리턴
        /// JSON : root 없이 json 결과 리턴
        /// NVP : name=value&name=value
        /// </summary>
        [StringLength(5)]
        public string format { get; set; }
    }
    #endregion

    #region 승인 결과 (결제 완료)
    /// <summary>
    /// 승인 결과 (결제 완료)
    /// </summary>
    public class InicisResult
    {
        #region 승인 결과 기본 데이터 필드
        /// <summary>
        /// 거래번호
        /// </summary>
        [StringLength(40)]
        public string tid { get; set; }
        /// <summary>
        /// 결과코드 (0000 : 정상, 기타 : 실패)
        /// </summary>
        [StringLength(10)]
        public string resultCode { get; set; }
        /// <summary>
        /// 결과메세지 (성공시 : OK, 실패시 : 기타 오류 메시지)
        /// </summary>
        [StringLength(100)]
        public string resultMsg { get; set; }
        /// <summary>
        /// 이벤트코드 (카드 할부 및 행사 적용 코드)
        /// </summary>
        [StringLength(3)]
        public string EventCode { get; set; }
        /// <summary>
        /// 거래금액
        /// </summary>
        [StringLength(20)]
        public string TotPrice { get; set; }
        /// <summary>
        /// 이니시스 주문번호 (결제 요청 시 "oid" 필드에 설정된 값)
        /// </summary>
        [StringLength(12)]
        public string MOID { get; set; }
        /// <summary>
        /// 지불수단 (결제 방법)
        /// </summary>
        [StringLength(10)]
        public string payMethod { get; set; }
        /// <summary>
        /// 승인번호 (결제수단에 따리 미전송)
        /// </summary>
        [StringLength(16)]
        public string applNum { get; set; }
        /// <summary>
        /// 승인일자 (YYYYMMDD)
        /// </summary>
        [StringLength(8)]
        public string applDate { get; set; }
        /// <summary>
        /// 승인시간 (hh24miss)
        /// </summary>
        [StringLength(6)]
        public string applTime { get; set; }
        /// <summary>
        /// 구매자 Email
        /// </summary>
        [StringLength(60)]
        public string buyerEmail { get; set; }
        /// <summary>
        /// 구매자 Mobile 번호 (예 “010-2000-1234”)
        /// </summary>
        [StringLength(20)]
        public string buyerTel { get; set; }
        /// <summary>
        /// 구매자명
        /// </summary>
        [StringLength(30)]
        public string buyerName { get; set; }
        /// <summary>
        /// 가맹점 데이터 (인증 성공시 가맹점으로 리턴)
        /// 유비케어 주문번호로 사용
        /// </summary>
        [StringLength(2000)]
        public string merchantData { get; set; }
        #endregion
        #region 승인 결과 추가 필드 사항
        public string parentemail { get; set; }
        public string p_Sub { get; set; }
        public string mid { get; set; }
        public string authSignature { get; set; }
        public string goodname { get; set; }
        public string goodsName { get; set; }
        public string FlgNotiSendChk { get; set; }
        public string p_SubCnt { get; set; }
        public string custEmail { get; set; }
        #endregion
        #region 승인 결과 (신용카드) 데이터 필드
        /// <summary>
        /// 카드번호
        /// </summary>
        [StringLength(16)]
        public string CARD_Num { get; set; }
        /// <summary>
        /// 무이자할부 여부 ("1"이면 무이자할부)
        /// </summary>
        [StringLength(1)]
        public string CARD_Interest { get; set; }
        /// <summary>
        /// 할부기간
        /// </summary>
        [StringLength(2)]
        public string CARD_Quota { get; set; }
        /// <summary>
        /// 신용카드사 코드
        /// </summary>
        [StringLength(2)]
        public string CARD_Code { get; set; }
        /// <summary>
        /// 부분취소 가능여부 (1:가능, 0:불가능)
        /// </summary>
        [StringLength(1)]
        public string CARD_PRTC_CODE { get; set; }
        /// <summary>
        /// 신용카드 발급사(은행) 코드 (매뉴얼 참조)
        /// </summary>
        [StringLength(2)]
        public string CARD_BankCode { get; set; }
        /// <summary>
        /// 간편(앱)결제 구분
        /// C : PAYCO, B : 삼성페이, D : 삼성페이(체크), G : SSGPAY, O : KAKAOPAY, L : LPAY, K : 국민앱카드, A : KPAY
        /// </summary>
        [StringLength(1)]
        public string CARD_SrcCode { get; set; }
        /// <summary>
        /// 카드포인트 사용여부
        /// “” : 카드 포인트 사용안함, “1” : 카드 포인트 사용
        /// </summary>
        [StringLength(1)]
        public string CARD_Point { get; set; }
        /// <summary>
        /// 통화코드 (달러결제 정보, 통화코드)
        /// </summary>
        [StringLength(3)]
        public string currency { get; set; }
        /// <summary>
        /// OK CASHBAG 카드번호
        /// </summary>
        [StringLength(20)]
        public string OCB_Num { get; set; }
        /// <summary>
        /// OK CASHBAG 적립 승인번호
        /// </summary>
        [StringLength(12)]
        public string OCB_SaveApplNum { get; set; }
        /// <summary>
        /// OK CASHBAG 사용내역 승인번호
        /// </summary>
        [StringLength(12)]
        public string OCB_PayApplNum { get; set; }
        /// <summary>
        /// OK CASHBAG 승인일시
        /// </summary>
        [StringLength(8)]
        public string OCB_ApplDate { get; set; }
        /// <summary>
        /// OK CASHBAG 포인트지불금액
        /// </summary>
        [StringLength(12)]
        public string OCB_PayPrice { get; set; }
        /// <summary>
        /// 달러 환전금액
        /// 해외카드 + 달러(USD) 결제 일 경우 환전금액
        /// (국내카드로 달러 결제 시 환전금액으로 표기X)
        /// </summary>
        [StringLength(20)]
        public string OrgPrice { get; set; }
        public string CARD_CheckFlag { get; set; }
        public string GSPT_Num { get; set; }
        public string GSPT_Remains { get; set; }
        public string UNPT_CardNum { get; set; }
        public string UPNT_UsablePoint { get; set; }
        #endregion
        #region 승인 결과 (무통장) 데이터 필드 - 가상계좌
        /// <summary>
        /// 입금 계좌 번호
        /// </summary>
        [StringLength(20)]
        public string VACT_Num { get; set; }
        /// <summary>
        /// 입금 은행 코드
        /// </summary>
        [StringLength(2)]
        public string VACT_BankCode { get; set; }
        /// <summary>
        /// 예금주명
        /// </summary>
        [StringLength(20)]
        public string VACT_Name { get; set; }
        /// <summary>
        /// 송금자명
        /// </summary>
        [StringLength(20)]
        public string VACT_InputName { get; set; }
        /// <summary>
        /// 송금 날짜
        /// </summary>
        [StringLength(8)]
        public string VACT_Date { get; set; }
        /// <summary>
        /// 송금 시간
        /// </summary>
        [StringLength(6)]
        public string VACT_Time { get; set; }
        /// <summary>
        /// 무통장 입금 은행명
        /// </summary>
        [StringLength(20)]
        public string vactBankName { get; set; }
        
        #endregion
        #region 승인 결과 (계좌이체) 데이터 필드
        /// <summary>
        /// 은행코드
        /// </summary>
        [StringLength(2)]
        public string ACCT_BankCode { get; set; }
        /// <summary>
        /// 결과코드 (220000(정상처리))
        /// </summary>
        [StringLength(10)]
        public string CSHR_ResultCode { get; set; }
        /// <summary>
        /// 발급구분코드 (0 = 소득공제 / 1 = 지출증빙)
        /// </summary>
        [StringLength(1)]
        public string CSHR_Type { get; set; }
        /// <summary>
        /// 계좌주명
        /// </summary>
        [StringLength(30)]
        public string ACCT_Name { get; set; }
        #endregion
        #region 승인 결과 (휴대폰 결제) 데이터 필드
        /// <summary>
        /// 휴대폰번호
        /// </summary>
        [StringLength(14)]
        public string HPP_Num { get; set; }
        /// <summary>
        /// 결제장치 (PC)
        /// </summary>
        [StringLength(6)]
        public string payDevice { get; set; }
        #endregion
        #region 승인 결과 (포인트) 데이터 필드
        /// <summary>
        /// 지불구분 (OCBpay/OCBplus/OCBpayonly/OCBboth/GSPTpay)
        /// </summary>
        [StringLength(10)]
        public string PayOption { get; set; }
        /// <summary>
        /// OK CashBag 카드 번호
        /// </summary>
        //[StringLength(20)]
        //public string OCB_Num { get; set; }
        /// <summary>
        /// OK CashBag 지불 금액
        /// </summary>
        //[StringLength(12)]
        //public string OCB_PayPrice { get; set; }
        /// <summary>
        /// U포인트 카드번호
        /// </summary>
        [StringLength(16)]
        public string UPoint_Num { get; set; }
        /// <summary>
        /// U포인트 가용포인트
        /// </summary>
        [StringLength(12)]
        public string UPoint_usablePoint { get; set; }
        /// <summary>
        /// U포인트 승인요청 금액
        /// </summary>
        [StringLength(12)]
        public string UPoint_ApplPrice { get; set; }
        /// <summary>
        /// U포인트 지불구분
        /// </summary>
        [StringLength(10)]
        public string UPNT_PayOption { get; set; }
        /// <summary>
        /// U포인트 복합결제시 여신 승인금액
        /// </summary>
        [StringLength(16)]
        public string UPNT_SavePrice { get; set; }
        /// <summary>
        /// U포인트 지불 금액
        /// </summary>
        [StringLength(9)]
        public string UPNT_PayPrice { get; set; }
        /// <summary>
        /// GS포인트 승인금액
        /// </summary>
        [StringLength(15)]
        public string GSPT_ApplPrice { get; set; }
        /// <summary>
        /// GS포인트 적립금액
        /// </summary>
        [StringLength(15)]
        public string GSPT_SavePrice { get; set; }
        /// <summary>
        /// GS포인트 승인금액
        /// </summary>
        [StringLength(15)]
        public string GSPT_PayPrice { get; set; }
        #endregion
        #region 승인 결과 (상품권) 데이터 필드
        /// <summary>
        /// 컬쳐랜드 고객ID
        /// </summary>
        [StringLength(20)]
        public string CULT_UserID { get; set; }
        /// <summary>
        /// 사용한 카드 개수
        /// </summary>
        [StringLength(1)]
        public string GAMG_Cnt { get; set; }
        /// <summary>
        /// 게임문화상품권 승인금액
        /// </summary>
        [StringLength(12)]
        public string GAMG_ApplPrice { get; set; }
        /// <summary>
        /// 스마트문화상품권 카드번호1
        /// </summary>
        [StringLength(18)]
        public string GAMG_Num1 { get; set; }
        /// <summary>
        /// 스마트문화상품권 카드결제금액1
        /// </summary>
        [StringLength(12)]
        public string GAMG_Price1 { get; set; }
        /// <summary>
        /// 스마트문화상품권 카드번호2
        /// </summary>
        [StringLength(18)]
        public string GAMG_Num2 { get; set; }
        /// <summary>
        /// 스마트문화상품권 카드결제금액2
        /// </summary>
        [StringLength(12)]
        public string GAMG_Price2 { get; set; }
        /// <summary>
        /// 스마트문화상품권 카드번호3
        /// </summary>
        [StringLength(18)]
        public string GAMG_Num3 { get; set; }
        /// <summary>
        /// 스마트문화상품권 카드결제금액3
        /// </summary>
        [StringLength(12)]
        public string GAMG_Price3 { get; set; }
        /// <summary>
        /// 스마트문화상품권 카드번호4
        /// </summary>
        [StringLength(18)]
        public string GAMG_Num4 { get; set; }
        /// <summary>
        /// 스마트문화상품권 카드결제금액4
        /// </summary>
        [StringLength(12)]
        public string GAMG_Price4 { get; set; }
        /// <summary>
        /// 스마트문화상품권 카드번호5
        /// </summary>
        [StringLength(18)]
        public string GAMG_Num5 { get; set; }
        /// <summary>
        /// 스마트문화상품권 카드결제금액5
        /// </summary>
        [StringLength(12)]
        public string GAMG_Price5 { get; set; }
        /// <summary>
        /// 스마트문화상품권 카드번호6
        /// </summary>
        [StringLength(18)]
        public string GAMG_Num6 { get; set; }
        /// <summary>
        /// 스마트문화상품권 카드결제금액6
        /// </summary>
        [StringLength(12)]
        public string GAMG_Price6 { get; set; }
        /// <summary>
        /// 틴캐시 승인금액
        /// </summary>
        [StringLength(12)]
        public string TEEN_ApplPrice { get; set; }
        /// <summary>
        /// 틴캐시 아이디
        /// </summary>
        [StringLength(16)]
        public string TEEN_UserID { get; set; }
        /// <summary>
        /// 틴캐시 승인번호
        /// </summary>
        [StringLength(8)]
        public string TEEN_ApplNum { get; set; }
        /// <summary>
        /// 도서상품권 승인 금액
        /// </summary>
        [StringLength(12)]
        public string BCSH_ApplPrice { get; set; }
        /// <summary>
        /// 도서상품권 사용자ID
        /// </summary>
        [StringLength(20)]
        public string BCSH_UserID { get; set; }
        /// <summary>
        /// 도서상품권 승인 번호
        /// </summary>
        [StringLength(12)]
        public string BCSH_ApplNum { get; set; }
        #endregion
        #region 승인 결과 (전화결제) 데이터 필드
        /// <summary>
        /// 승인 전화번호
        /// </summary>
        [StringLength(12)]
        public string PHNB_Num { get; set; }
        #endregion
        #region 승인 결과 (전자지갑[뱅크월렛]) 데이터 필드
        /// <summary>
        /// 휴대폰번호
        /// </summary>
        [StringLength(40)]
        public string KWPY_CellPhone { get; set; }
        /// <summary>
        /// 거래금액
        /// </summary>
        [StringLength(12)]
        public string KWPY_SalesAmount { get; set; }
        /// <summary>
        /// 공급가액
        /// </summary>
        [StringLength(12)]
        public string KWPY_Amount { get; set; }
        /// <summary>
        /// 부가세
        /// </summary>
        [StringLength(12)]
        public string KWPY_Tax { get; set; }
        /// <summary>
        /// 봉사료
        /// </summary>
        [StringLength(12)]
        public string KWPY_ServiceFee { get; set; }
        #endregion
    }
    #endregion
}


Flutter #0

[Flutter 교육] Dart vs JavaScript 타입 시스템 비교 1. 기본 타입 차이 숫자 타입 // Dart int integerNumber = 42; // 정수 double floatingPoint = 3.14; // 부...