자유롭게 질의 및 응답을 할 수 있는 게시판입니다. 개발자 여러분의 답변이 큰 도움이 됩니다. 
- 제품설치/등록 오류 문의: 설치/등록 Q&A 이용 (제품 구매 고객 한정)
			Delphi			FormatDateTime 함수 사용시.
		
		
			2016.01.18 01:04		
		
	
	
	
		
	
	
				본 게시판 사용시 당부 사항
* 이 게시판은 자유롭게 질문을 올리고 자발적으로 답변을 공유하는 게시판입니다.
* 어느 누구도 답변을 달아야만 하는 책임은 없습니다.
* 따라서 질문을 올리실 때에는 최대한 자세하고 정중하게 질문을 올려 주세요.
* 최대한 질문을 자세히 올려야 답변도 자세히 올라 옵니다.
* 본 질문에 답변을 주시는 여러 개발자님들께 미리 감사드립니다.
-----------------------------------------------------------------------------------------------
 ShowMessage(FormatDateTime('yyyy-mm-dd', Now())); 
 <-위 문장은 정상적을 날자 표시됨.
//dbExpress로 연결시 
   with SQLQuery1 do begin
      Sql.Clear;
      Sql.Add('select getdate() dt');
      Open;
      ShowMessage(FormatDateTime('yyyy-mm-dd', FieldByName('dt').AsDateTime)); 
      <- 위문장은 Invalid argument to time encode라는 에러가 나타남...
   어떤 차이 일까요..?
   FireDAC로 연결시도 에러가 났던걸로 기억 합니다..
   쿼리문으로 getdate()를 cast함수 사용하여 string으로 가져 올수 있으나 
   위 문장이 왜 안되는지 알고 싶습니다.
   DB연결시 날자에 대한 속성을 설정 해 주어야 되는게 아닌가 싶습니다...
   읽어주셔서 감사합니다..   
 
			
	
	
	
	
	
		댓글 3
	
	
		- 
			
						
		
- 
			
												
															공감				2016.01.18 11:06 select getdate() dt  문장에서 getdate()함수는 SQL에서 DateTime형식이지 않나요.? 또 DB에서  테이블을 만들시 create table test(    idate datetime null ) 이렇게 테이블을 만들고 idate에 데이타를 넣고 select idate from test   FormatDateTime('yyyy-mm-dd', FieldByName('idate').AsDateTime));  이렇게 해도 동일 에러가 납니다..      
- 
			
						FormatDateTime('yyyy-mm-dd', FieldByName('dt').AsDateTime)   위 문장에서 오류가 날 수 있는 부분은 .AsDateTime과 FormatDateTime 두곳입니다.   먼저 TDateTime 타입의 변수에 AsDateTime으로 넣어보시기 바랍니다.(제가 보기에는 여기에서 오류가 날 것 같네요.) 만약 맞다면 AsString으로 받아와 어떻게 찍히는지 확인해 보시기 바랍니다. 
Delphi FormatDateTime 함수 사용시.
2016.01.18 01:04
본 게시판 사용시 당부 사항
* 이 게시판은 자유롭게 질문을 올리고 자발적으로 답변을 공유하는 게시판입니다.
* 어느 누구도 답변을 달아야만 하는 책임은 없습니다.
* 따라서 질문을 올리실 때에는 최대한 자세하고 정중하게 질문을 올려 주세요.
* 최대한 질문을 자세히 올려야 답변도 자세히 올라 옵니다.
* 본 질문에 답변을 주시는 여러 개발자님들께 미리 감사드립니다.
-----------------------------------------------------------------------------------------------
 ShowMessage(FormatDateTime('yyyy-mm-dd', Now())); 
 <-위 문장은 정상적을 날자 표시됨.
//dbExpress로 연결시 
   with SQLQuery1 do begin
      Sql.Clear;
      Sql.Add('select getdate() dt');
      Open;
      ShowMessage(FormatDateTime('yyyy-mm-dd', FieldByName('dt').AsDateTime)); 
      <- 위문장은 Invalid argument to time encode라는 에러가 나타남...
   어떤 차이 일까요..?
   FireDAC로 연결시도 에러가 났던걸로 기억 합니다..
   쿼리문으로 getdate()를 cast함수 사용하여 string으로 가져 올수 있으나 
   위 문장이 왜 안되는지 알고 싶습니다.
   DB연결시 날자에 대한 속성을 설정 해 주어야 되는게 아닌가 싶습니다...
   읽어주셔서 감사합니다..   
 
댓글 3
- 
			공감2016.01.18 11:06 select getdate() dt 문장에서 getdate()함수는 SQL에서 DateTime형식이지 않나요.? 또 DB에서 테이블을 만들시 create table test( idate datetime null ) 이렇게 테이블을 만들고 idate에 데이타를 넣고 select idate from test FormatDateTime('yyyy-mm-dd', FieldByName('idate').AsDateTime)); 이렇게 해도 동일 에러가 납니다.. 
- 
			
						FormatDateTime('yyyy-mm-dd', FieldByName('dt').AsDateTime) 위 문장에서 오류가 날 수 있는 부분은 .AsDateTime과 FormatDateTime 두곳입니다. 먼저 TDateTime 타입의 변수에 AsDateTime으로 넣어보시기 바랍니다.(제가 보기에는 여기에서 오류가 날 것 같네요.) 만약 맞다면 AsString으로 받아와 어떻게 찍히는지 확인해 보시기 바랍니다. 
 
                                            

 
								 
				
dt 필드를 DateTime으로 캐스팅(AsDateTime) 시 발생하는 오류로 보입니다.
dt 필드의 실제 DB 포이 DateTime인지 확인해 보시기 바랍니다.