文档章节

sqlite数据类型 datetime处理

jackguo
 jackguo
发布于 2015/03/03 17:01
字数 1800
阅读 85
收藏 0

SQLite包括以下五个时间函数: 

date(日期时间字符串, 修正符, 修正符, ……) 

time(日期时间字符串, 修正符, 修正符, ……) 

datetime(日期时间字符串, 修正符, 修正符, ……) 

julianday(日期时间字符串, 修正符, 修正符, ……) 

strftime(日期时间格式, 日期时间字符串, 修正符, 修正符, ……) 

上述五个函数需要一个日期时间字符串做参数,后面可以跟零到多个修正符参数。而 strftime() 函数还需要一个日期时间格式字符串做第一个参数。 

date() 函数返回一个以 “YYYY-MM-DD” 为格式的日期; 

time() 函数返回一个以 “YYYY-MM-DD HH:MM:SS” 为格式的日期时间; 

julianday() 函数返回一个天数,从格林威治时间公元前4714年11月24号开始算起; 

strftime() 函数返回一个经过格式话的日期时间,它可以用下面的符号对日期和时间进行格式化: 

%d 一月中的第几天 01-31  
%f 小数形式的秒,SS.SSSS  
%H 小时 00-24  
%j 一年中的第几天 01-366  
%J Julian Day Numbers  
%m 月份 01-12  
%M 分钟 00-59  
%s 从 1970-01-01日开始计算的秒数  
%S 秒 00-59  
%w 星期,0-6,0是星期天  
%W 一年中的第几周 00-53  
%Y 年份 0000-9999  
%% % 百分号 
其他四个函数都可以用 strftime() 函数来表示: 

date(…)        ->  strftime(“%Y-%m-%d”,…)  
time(…)        ->  strftime(“%H:%M:%S”,…)  
datetime(…)   ->  strftime(“%Y-%m-%d %H:%M:%S”,…)  
julianday(…)  ->  strftime(“%J”,…) 
日期时间字符串,可以用以下几种格式: 

YYYY-MM-DD  
YYYY-MM-DD HH:MM  
YYYY-MM-DD HH:MM:SS  
YYYY-MM-DD HH:MM:SS.SSS  
YYYY-MM-DDTHH:MM  
YYYY-MM-DDTHH:MM:SS  
YYYY-MM-DDTHH:MM:SS.SSS  
HH:MM  
HH:MM:SS  
HH:MM:SS.SSS  
now  
DDDD.DDDD 
在第五种到第七种格式中的“T”是一个分割日期和时间的字符;第八种到第十种格式只代表2000-01-01日的时间,第十一种格式的’now’表示返回一个当前的日期和时间,使用格林威治时间(UTC);第十二种格式表示一个 Julian Day Numbers。 

修正符 

日期和时间可以使用下面的修正符来更改日期或时间: 

NNN days  
NNN hours  
NNN minutes  
NNN.NNNN seconds  
NNN months  
NNN years  
start of month  
start of year  
start of week  
start of day  
weekday N  
unixepoch  
localtime  
utc 
前六个修正符就是简单的增加指定数值的时间和日期;第七到第十个修正符表示返回当前日期的开始;第十一个修正符表示返回下一个星期是N的日期和时间;第十二个修正符表示返回从1970-01-01开始算起的秒数;第十三个修正符表示返回本地时间。 

下面举一些例子: 

计算机当前时间 
SELECT date(‘now’)

 
计算机当前格林威治时间 
SELECT date(‘now’,’start of month’,’+1 month’,’-1 day’)

 
计算UNIX 时间戳1092941466表示的日期和时间 
SELECT datetime(‘1092941466’,’unixepoch’) 


计算 UNIX 时间戳1092941466 表示的本地日期和时间 
SELECT datetime(‘1092941466’,’unixepoch’,’localtime’)

 
计算机当前UNIX 时间戳 
SELECT strftime(‘%s’,’now’)

 
两个日期之间相差多少天 
SELECT jolianday(‘now’)-jolianday(‘1981-12-23’)

 
两个日期时间之间相差多少秒 
SELECT julianday('now')*86400 - julianday('2004-01-01 02:34:56')*86400

 
计算今年十月份第一个星期二的日期 
SELECT date('now','start of year','+9 months','weekday 2');

 
得到年 
strftime(‘%y’,'2008-4-28')

 
得到月 
strftime(‘%m’,'2008-4-28')

 
同样,我们也可以通过strftime来得到其它所要的信息,但是要记得,给时间加引号 

例1.  
select datetime('now');  
结果:2006-10-17 12:55:54  

例2.  
select datetime('2006-10-17');  
结果:2006-10-17 12:00:00  

例3.  
select datetime('2006-10-17 00:20:00','+1 hour','-12 minute');  
结果:2006-10-17 01:08:00  

例4.  
select date('2006-10-17','+1 day','+1 year');  
结果:2007-10-18  

例5.  
select datetime('now','start of year');  
结果:2006-01-01 00:00:00  

例6.  
select datetime('now','start of month');  
结果:2006-10-01 00:00:00  

例7.  
select datetime('now','start of day');  
结果:2006-10-17 00:00:00  

例8.  
select datetime('now','+10 hour','start of day','+10 hour');  
结果:2006-10-17 10:00:00  

例9.  
select datetime('now','localtime');  
结果:2006-10-17 21:21:47  

例10.  
select datetime('now','+8 hour');  
结果:2006-10-17 21:24:45 
例3中的+1 hour和-12 minute表示可以在基本时间上(datetime函数的第一个参数)增加或减少一定时间。 

例5中的start of year表示一年开始的时间。 

从例8可以看出,尽管第2个参数加上了10个小时,但是却被第3个参数“start of day”把时间归零到00:00:00,随后的第4个参数在00:00:00 
的基础上把时间增加了10个小时变成了10:00:00。 

例9把格林威治时区转换成本地时区。 

例10把格林威治时区转换成东八区。 

strftime()函数可以把YYYY-MM-DD HH:MM:SS格式的日期字符串转换成其它形式的字符串。 

strftime()的语法是strftime(格式, 日期/时间, 修正符, 修正符, ...) 

它可以用以下的符号对日期和时间进行格式化: 

%d 月份, 01-31  
%f 小数形式的秒,SS.SSS  
%H 小时, 00-23  
%j 算出某一天是该年的第几天,001-366  
%m 月份,00-12  
%M 分钟, 00-59  
%s 从1970年1月1日到现在的秒数  
%S 秒, 00-59  
%w 星期, 0-6 (0是星期天)  
%W 算出某一天属于该年的第几周, 01-53  
%Y 年, YYYY  
%% 百分号 
strftime()的用法举例如下: 

例11.  
select strftime('%Y.%m.%d %H:%M:%S','now','localtime');  
结果:2006.10.17 21:41:09 
例11用圆点作为日期的分隔附,并把时间转换为当地的时区的时间。 

小结:iPhone应用程序中Sqlite时间函数及时间处理的内容介绍完了,希望本文对你有所帮助! 

What I do is use sqlite's current_timestamp (which looks something like this: 2009-06-16 12:11:24). To do this just set the row type of your qslite table to 

Data type: "DATETIME" 
Allow null: NO 
Default value: CURRENT_TIMESTAMP 
Then use an SQL query like this: 

@"INSERT INTO 'scores' ('one', 'two', 'three') VALUES ('%d', '%d', '%d')" 
ignoring the date, so that it will automatically get the current time value. 

Then to convert this to an NSDate you can use an NSDateFormatter like this: 

NSDateFormatter *formatter = [[NSDateFormatter alloc] init]; 
[formatter setDateFormat:@"yyyy-MM-dd HH:mm:ss"]; //this is the sqlite's format 
NSDate *date = [formatter dateFromString:score.datetime]; 
and now you have that date as an NSDate object. Just don't forget to release the NSDateFormatter we allocated 

 刚刚记忆完毕 100 % 
  20分钟之后 58.2% 
  1小时之后 41.2% 
  8-9小时之后 35.8% 
  1天后 33.7% 
  2天后 27.8% 
  8天后 25.4% 
  1个月后 21.1% 

DELETE from Chapters; 

insert into Chapters VALUES ('1','第一章',CURRENT_TIMESTAMP,(select datetime(CURRENT_TIMESTAMP, '+20 minutes'))); 
insert into Chapters VALUES ('2','第二章',CURRENT_TIMESTAMP,(select datetime(CURRENT_TIMESTAMP, '+20 minutes'))); 
insert into Chapters VALUES ('3','第三章',CURRENT_TIMESTAMP,(select datetime(CURRENT_TIMESTAMP, '+20 minutes'))); 


/* 
select datetime('2012-03-16 15:14:10.487', '+20 minute');  
*/ 


select * from Chapters; 

datetime('now')格林威治时间,一般很少用到 
datetime('now', 'localtime')本地时间,经常使用用于获取当前时间


本文转载自:http://blog.csdn.net/knxw0001/article/details/13294781

共有 人打赏支持
jackguo
粉丝 15
博文 170
码字总数 40034
作品 0
海淀
系统管理员
sqlite3中BLOB数据类型存储大对象运用示例

1:常用接口 个人比较喜欢sqlite, 使用最方便,唯一的准备工作是下载250K的源;而且作者很热心,有问必答。 以下演示一下使用sqlite的步骤,先创建一个数据库,然后查询其中的内容。2个重要结...

涩女郎
2015/08/26
0
0
【原创】如何在 libgda 和 SQLite 之间作出选择

How to choose between Libgda and SQLite 如何在 libgda 和 SQLite 之间作出选择 (本文为官方文档翻译,以中英对照形式呈现) Libgda has been added as a new external dependency for G...

摩云飞
2013/03/20
0
0
2010年SQLite学习笔记之二(2)

创建数据库文件: >SQLite3 d:/test.db 回车 就生成了一个test.db在d盘。 这样同时也SQLite3挂上了这个test.db 2) 用.help可以看看有什么命令 >.help 回车即可 3)可以在这里直接输入SQL语句创...

jpch
2013/12/11
0
0
[转载]SQLite 创建、修改、删除表

、数据库定义语言 DDL 在关系型数据库中,数据库中的表 Table、视图 View、索引 Index、关系 Relationship 和触发器 Trigger 等等,构成了数据库的架构 Schema。 在 SQL 语句中,专门有一些语...

mutouzhang
2014/03/25
0
0
安卓应用安全指南 4.5.3 使用 SQLite 高级话题

安卓应用安全指南 4.5.3 使用 SQLite 高级话题 原书:Android Application Secure Design/Secure Coding Guidebook 译者:飞龙 协议:CC BY-NC-SA 4.0 4.5.3.1 在 SQL 语句的断言中使用通配符...

apachecn_飞龙
03/22
0
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

jetbrains系产品IDEA:mac上面提示快捷键设置

原因 由于Mac上面的Ctrl+空格变成输入法切换的快捷键,在使用IDEA的过程中,代码提示很不方便,需要使用option+/这种传统eclipse上面的代码提示快捷键作为主要快捷键。 怎么修改? 移除【opt...

亚林瓜子
35分钟前
0
0
Exclipse 输出结果时换行

System.out.println(f1 + "\n" + d1 + "\n" + d2);

笑丶笑
35分钟前
1
0
怎样治疗标签不能触发onblur事件

I realize this was over a year ago, but it showed up for me in Google while trying to solve this same issue. It seems Chrome does not consider some elements, like body and ancho......

Weijuer
39分钟前
0
0
vue常见库安装

移动设备上的浏览器默认会在用户点击屏幕大约延迟300毫秒后才会触发点击事件,这是为了检查用户是否在做双击。为了能够立即响应用户的点击事件,才有了FastClick。 安装fastclick npm insta...

林夏夕
40分钟前
0
0
kafka 教程(三) kafka Java API 编程

下午写

MrPei
41分钟前
0
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部