자유롭게 질의 및 응답을 할 수 있는 게시판입니다. 개발자 여러분의 답변이 큰 도움이 됩니다.
- 제품설치/등록 오류 문의: 설치/등록 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 09:03
-
공감
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)); 이렇게 해도 동일 에러가 납니다..
-
험프리
2016.01.22 16:58
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 09:03
-
공감
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)); 이렇게 해도 동일 에러가 납니다..
-
험프리
2016.01.22 16:58
FormatDateTime('yyyy-mm-dd', FieldByName('dt').AsDateTime)
위 문장에서 오류가 날 수 있는 부분은
.AsDateTime과 FormatDateTime 두곳입니다.
먼저 TDateTime 타입의 변수에 AsDateTime으로 넣어보시기 바랍니다.(제가 보기에는 여기에서 오류가 날 것 같네요.)
만약 맞다면 AsString으로 받아와 어떻게 찍히는지 확인해 보시기 바랍니다.
dt 필드를 DateTime으로 캐스팅(AsDateTime) 시 발생하는 오류로 보입니다.
dt 필드의 실제 DB 포이 DateTime인지 확인해 보시기 바랍니다.