NSDate를 SQLite DB에 저장을 해야 할일이 생겼습니다.
어떻게 할까 고민을 좀 해봤습니다.
NSDateFormatter를 이용해서, String으로 변환시킨후 저장을 하고, 다시 Formatter를 이용해서 NSDate로 Parsing하는 방법이 있는데,
Raw Data가 아닌 변환된값을쓴다는점과, Parsing에 들아가는 Cost등을 고려할때 좋은 방법이 아닐듯 싶습니다.
그래서 생각을 해보았는데, NSTimeInterval을 이용하기로 하였습니다.
NSDate에는 NSTimerInterval을 구해주는 여러 메소드가 있습니다.
timeIntervalSince1970을 이용하면, 1970년 1월 1일 부터의 duration을 second 단위로 얻을수 있습니다.
이걸 SQLite에 저장해두고, 다시 불러다가 쓰면 깔끔하게 구현이 될것 같습니다.
NSTimeInterval은 실제론 double 을 typedef 해서 정의된 자료형이기때문에, SQLITE의 column type을 'REAL'로 정의해서 저장하도록합니다.
DB Schema는 정의되어 있다고 가정하고, 아래는 NSTimeInterval을 DB에 삽입하는 코드 입니다.
그럼 DB에서 가져오는 코드를 보도록 하겠습니다.
첨에는 좀 까다롭지 않을까 싶었는데, 뭐 딱히 어려운게 없습니다 ㅎ
그냥 스윽~하면 스윽~되는거죠 ㅎㅎ
필요하시면 아래 예제 소스를 참조 하시고, 좋은 어플들 많이 개발하세요 ^^