728x90
mysql 로 prepared statement API(C) 로 DB 작업을 할때, time 필드 처리를 하다가 time 타입의 range 가 생각과는 다르게 입력이 되는 것을 오늘에서야 알게 되었다.
MYSQL_TIME ts; MYSQL_BIND bind[3]; MYSQL_STMT *stmt; strmov(query, "INSERT INTO test_table(date_field, time_field, \ timestamp_field) VALUES(?,?,?"); stmt = mysql_stmt_init(mysql); if (!stmt) { fprintf(stderr, " mysql_stmt_init(), out of memory\n"); exit(0); } if (mysql_stmt_prepare(mysql, query, strlen(query))) { fprintf(stderr, "\n mysql_stmt_prepare(), INSERT failed"); fprintf(stderr, "\n %s", mysql_stmt_error(stmt)); exit(0);
}
/* set up input buffers for all 3 parameters */ bind[0].buffer_type= MYSQL_TYPE_DATE; bind[0].buffer= (char *)&ts; bind[0].is_null= 0; bind[0].length= 0; ... bind[1]= bind[2]= bind[0]; ... mysql_stmt_bind_param(stmt, bind); /* supply the data to be sent in the ts structure */ ts.year= 2002; ts.month= 02; ts.day= 03; ts.hour= 10; ts.minute= 45; ts.second= 20; mysql_stmt_execute(stmt);
..
실행해보면, 위 코드에서 date_field 는 의도한대로 '2002-02-03' 이 있는 것을 확인할 수 있다. 그런데, time_field 는 '10:45:20' 이 아니라 '-82:45:20' 와 같이 시간부분이 마이너스가 들어가 있는것을 볼 수 있다.
time_ 필드 정의(http://dev.mysql.com/doc/refman/5.0/en/time.html)를 찾아보니 범위가 '-839:59:59' 에서 '839:59:59' 라고 되어 있다.
메뉴얼의 처음 부분 "but also elapsed time or a time interval between two events" 이라고 나오기 때문에 "date_add()", "date_sub()" 를 표현하기 위함은 알 수 있으나, 왠지 설명이 빠져있는거 같아서 다른 자료(http://jiansenlu.blogspot.kr/2012/11/mysql-date-and-time-type.html)를 찾아보니, 'HHH' 가 'D*24 + HH' 이란 의미로 나온다.
'Engineering > DB' 카테고리의 다른 글
rownum 표현 방법 (0) | 2013.07.05 |
---|---|
HandlerSocket plugin for MySQL 정리 (0) | 2012.12.28 |
MySQL 에서 테이블 스키마만 가져오려고 하는 경우 (0) | 2011.09.27 |
FreeTDS 라이브러리 사용시, "FreeTDS: db-lib: exiting because client error handler returned 0 for msgno 2000" 에러 발생시 해결방안 (0) | 2011.08.18 |
MySQL UTF-8 지원 설정 (0) | 2011.07.18 |