core data 的NSDate 属性类型和sqlite3的timestamp字段类型之间的相互转换
来源:互联网 发布:罗永浩大战王自如知乎 编辑:程序博客网 时间:2024/06/06 23:50
core data直接支持NSDate类型的属性,在iOS里确实使用很方便。有时候我们需要在其他程序里直接访问sqlite文件,这一属性在底层的sqlite文件里是映射为Timestamp字段的。但是直接select出来这个字段并转换成Date类型,就会发现转换回来的日期出错了。举个列子,用python处理Coredata的sqlite,Coredata中存入的是2011-10-6,直接从Sqlite字段select并转换的日期变成1980-10-6。
这是因为coredata存储NSDate时,在内部是存储了字参考时间以来的NSTimeInterval(以秒计算),而这个参考时间根据apple dateandtimes doc, NSDate computes time as seconds relative to an absolute reference time: the first instant of January 1, 2001 GMT,没错,参考日期是2001.1.1,而非1970年1月1日,因此有些语言在直接读取coredata NSDate属性的sqlite Timestamp字段并转换成日期后,与原来存储的日期不一样了。
明白了问题出在哪,解决方法就多了,最简单的是select时用Sqlite的datetime进行转换
select datetime('2001-01-01', 字段名 || 'seconds') from table;
如需本地时间表示
select datetime('2001-01-01', 字段名 || 'seconds', 'localtime') from table;
如用 data函数,返回 YYYY-MM-DD
time函数,返回 HH:MM:SS
当然,如果需要跟自定义的输出,请参考sqlite中的 strftime()函数
- core data 的NSDate 属性类型和sqlite3的timestamp字段类型之间的相互转换
- String 和Timestamp类型的相互转换
- NSString和NSDate之间的相互转换
- NSDate和NSString之间的相互转换
- XMLGregorianCalendar类型和Date类型之间的相互转换
- XMLGregorianCalendar类型和Date类型之间的相互转换
- XMLGregorianCalendar类型和Date类型之间的相互转换
- MySQL DATETIME类型和Timestamp之间的转换
- MySQL DATETIME类型和Timestamp之间的转换
- Mysql中Unix TimeStamp类型和DateTime类型的相互转换
- JAVA变量类型之间的相互转换
- 基本类型之间的相互转换
- Java基本类型之间的相互转换
- 在枚举类型的值和字符串之间相互转换
- 在枚举类型的值和字符串之间相互转换
- java 中基本类型和字符串之间的相互转换
- c# string类型和json之间的相互转换
- NSString和NSDate对象之间的相互转换
- hibernate.bytecode.use_reflection_optimizer
- 常见的网络服务器软件综合比较介绍(apache、IIS、tomcat、jboss、resin、weblogic、websphere)
- 矩阵类的实现,运算符重载
- exception 异常 log4j
- 手把手教你制作一个Windows服务
- core data 的NSDate 属性类型和sqlite3的timestamp字段类型之间的相互转换
- java泛型
- 【转】JavaEE的13种核心技术规范
- log4j中对Exception的记录
- Java并发学习笔记(14) 闭锁(CountDownLatch)
- makefile 自动推导命令
- paoding庖丁分词使用小例子(学习笔记)
- 存在外连接的物化视图
- redhat5 linux vsftpd 添加ftp用户