SQLite中的日期基础

SQLite包含了如下时间/日期函数:

datetime().......................产生日期和时间

date()...........................产生日期

time()...........................产生时间

strftime().......................对以上三个函数产生的日期和时间进行格式化

datetime()的用法是:

datetime(日期/时间,修正符,修正符...)

date()和time()的语法与datetime()相同。

在时间/日期函数里可以使用如下格式的字符串作为参数:

YYYY-MM-DD

YYYY-MM-DD

HH:MM YYYY-MM-DD HH:MM:SS

YYYY-MM-DD HH:MM:SS.SSS

HH:MM

HH:MM:SS

HH:MM:SS.SSS

now

其中now是产生现在的时间。

举例(写这个笔记的时间是2006年10月17日晚8点到10点,测试环境:SQLite 2.8.17,WinXP,北京时间):

例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用圆点作为日期的分隔附,并把时间转换为当地的时区的时间。

原文地址:http://blog.csdn.net/derryzhang/article/details/5033155

时间: 2024-11-01 01:02:22

SQLite中的日期基础的相关文章

javascript中关于日期和时间的基础知识

× 目录 [1]标准时间 [2]字符串 [3]闰年[4]月日[5]星期[6]时分秒 前面的话 在介绍Date对象之前,首先要先了解关于日期和时间的一些知识.比如,闰年.UTC等等.深入了解这些,有助于更好地理解javascript中的Date对象.本文将介绍javascript关于日期和时间的基础知识 标准时间 一般而言的标准时间是指GMT和UTC,以前是GMT,现在是UTC GMT 格林尼治标准时间(GMT)是指位于伦敦郊区的皇家格林尼治天文台的标准时间,因为本初子午线被定义在通过那里的经线

[转载]SQL语句中的日期计算

1. 本月的第一天SELECT  DATEADD(mm,  DATEDIFF(mm,0,getdate()),  0) 2. 本月的最后一天SELECT  dateadd(ms,-3,DATEADD(mm,  DATEDIFF(m,0,getdate())+1,  0)) 3.上个月的第一天select dateadd(m,-1,  DATEADD(mm,  DATEDIFF(mm,0,getdate()),  0)) 4. 上个月的最后一天 SELECT  dateadd(ms,-3,DATE

SQLite 中的各种限制

英文原文:Limits In SQLite     本文定义了 SQLite 的限制,如何针对这些限制定制特定的应用程序.默认的限制设置通常是适当的,几乎适合于每一个应用.有一些应用程序可能需要在这里或者那里增加一个设置,但是我们估计这非常罕见.更普遍的是,应用程序可能需要重新编译SQLite以及更低的限制来避免过多的资源利用率,以及在高级SQL语句生成器上帮助阻止攻击者注入恶意SQL语句时发生错误. 在使用 sqlite3_limit() 接口的 limit categories 上,为该接口

使用VBA自动填写考勤模板中的日期栏位

首先说明一下,公司每个月末都要求员工填写考勤信息,然后发了个模板,我觉得每次都要填写日期和星期几这样的信息比较繁琐,所以就想了一个偷懒的办法,而且对模板样式也做了一下变更,使其信息展示效率得到了提高. 简单来那就是使用Office中自带的VBA功能来对考勤模板中类似日期这样有规律可循的栏位进行自动化的填写. 如图所示 这样每次填写考勤记录的时候只需填写月度栏位的信息,然后点击模板做成按钮就可以实现日期和星期栏位信息的自动化填写啦. [模板下载] PS:至于我在Excel中的VBA代码是怎么写的可

SQLite中使用时的数据类型注意

在使用SQLite时,要注意:在SQLite中的Integer类型,对应在C#中需要使用long类型或者Int64 在使用SQLite时,要注意:在SQLite中存放的日期类型必须是如此:yyyy-MM-dd HH:mm:ss 不能加毫秒,而且只能用“-”间隔. 在使用SQLite时,要注意:在SQLite中存放的Bool类型只能使用数字,不能使用'true'或'false'否则无法转换到C#中.读取会出错.

sqlite中的replace、insert、update之前的区别

本文转自http://www.ithao123.cn/content-933827.html,在此感谢作者 android数据库操作,有两种方式,一种用android提供给我们的数据库操作函数insert.update.replace,我用到的就是这三种.另外一种方式就是利用数据库语言进行操作,也就是利用execSQL这个函数后面带sqlite数据库操作语言进行操作,sqlite中的sql语言和标准的sql语言大同小异,但是你如果是想有针对性的了解,建议你买一本书<SQLite权威指南>,这本

ASP.NET中的C#基础知识

ASP.NET中的C#基础知识 说明:asp.net作为一种开发框架现在已经广为应用,其开发的基础除了前端的html.css.JavaScript等后端最重要的语言支持还是C#,下面将主要用到的基础知识做一个总结,方面后面的学习. 一.C#是一种面向对象的变成语言,主要用于开发可以在.net平台上运行的应用程序.是一种强类型语言,一次每个变量都必须具有声明类型.C#中有两种数据类型:值类型和引用类型.(其中值类型用于存储值,引用类型用于存储实际数据的引用). 1.值类型 值类型表示实际的数据,存

解析SQLite中的常见问题与总结详解

1. 创建数据如果不往数据库里面添加任何的表,这个数据库等于没有建立,不会在硬盘上产生任何文件,如果数据库已经存在,则会打开这个数据库. 2. 如何通过sqlite3.dll与sqlite3.def生成sqlite3.lib文件LIB /DEF:sqlite3.def /machine:IX86 3. sqlite3_open打开一个数据库时,如果数据库不存在就会新生成一个数据库文件.如果接着执行其他查询语句就会失败,比如sqlite3_prepare,编程中出现明明指定了数据库而且里面也有数据

Android的Sqlite中DateTime类型数据的存取问题

关于讲sqlite中日期类型数据的存取网上有不少,但发现讲得这么细的非常少.更多的是用Date,不用做日期数据统计分析,对存取要求比较小的直接转换成long,即dateTime.getTime()存储.需要在界面上显示的时候就再将long型的日期数据转化为Date或DateTime类型.但是如果要做数据统计分析的话这样每条记录都要遍历转换会显得特别麻烦,数据量大的话时间消费是很大的. 我们知道Date类型数据在数据库中是yyyy-MM-dd形式存的,而Time是HH:mm形式存的.而DateTi