记录一下,SQLite中nullif和ifnull的区别:

nullif(null,'')     --输出null
nullif('','')       --输出null
nullif('t','t')     --输出null
nullif('tl','t')    --输出tl
--看输出值发现,nullif是前后对比函数,一致返回null,否则返回第一个参数ifnull('','t')      --输出''
ifnull(null,'t')    --输出t
ifnull('tl','t')    --输出tl--两个函数区别一目了然

更多sqlite函数用法参考链接

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()的用法举例如下:
select strftime(‘%Y-%m-%d %H:%M:%S’,’now’,’localtime’);
结果:2016-12-15 12:43:08
其实更好的用法是这样的,比如统,本月或本年的支出:
select strftime(‘%Y-%m’,日期) as 月份,sum(支出) as 月支出 from 流水帐 group by 月份;


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。

修正符

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

  1. NNN days
  2. NNN hours
  3. NNN minutes
  4. NNN.NNNN seconds
  5. NNN months
  6. NNN years
  7. start of month
  8. start of year
  9. start of week
    10.start of day
    11.weekday N
    12.unixepoch
    13.localtime
    14.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用圆点作为日期的分隔附,并把时间转换为当地的时区的时间

在做ClinicOS的时候遇到一个问题,在保存病历登记时间时,我使用了“CURRENT_TIMESTAMP”,但这有个问题,它返回的是UTC Time,这对我们中国人没啥用,

Where julianday(date(‘now’, ‘localtime’)) - julianday(date(arrival_date)) > 7
嘿嘿,看来如果想得到一个符合本机区域设置的当前时间,必须用date函数来转换,
但date只函数只返回当前日期,而我需要的是返回当前日期及时间,所以这里把它换成datetime函数,即:
datetime(CURRENT_TIMESTAMP,’localtime’)
以下是sqlite下测试的输出信息:
sqlite> select CURRENT_TIMESTAMP;
2006-06-18 09:23:36
sqlite> select datetime(CURRENT_TIMESTAMP,’localtime’);
2006-06-18 17:23:44
sqlite>
比如今天是:200-02-22

运行如下语句所得到的结果不一样:

select date(‘now’)
结果:2009-02-21

select datetime(‘now’,’localtime’)
结果:2009-02-22 00:52:04

所以比较时用第二种语句才取得正确结果,例如(取大于现在时间的记录):

select * from 表 where 日期字段>datetime(‘now’,’localtime’)

好象没有MSSQL的datediff等函数

如下语句实现datediff(‘m’,开始日期,结束日期’)函数同一个数数据:

select * from 表 where strftime(‘%m’,日期字段)=strftime(‘%m’,’now’)

如此就可以实现了两个日期相比较,举一反三,同样使用strftime格式式日期来对日、周、年比较

参考Sqlite日期函数详细文档:

http://www.xueit.com/html/2009-02/27_649_00.html

select * from Placard where Placard_EndTime > datetime(‘now’);

Select Placard_StartTime,strftime(‘%s’,Placard_StartTime) , datetime(‘now’),strftime(‘%s’,’now’) FROM Placard

差8个时区…

Select Placard_StartTime,strftime(‘%s’,Placard_StartTime) , datetime(‘now’,’localtime’),strftime(‘%s’,’now’,’localtime’) FROM Placard

上一条:大于指定时间的第一条

select title,pubtime from article where pubtime>’2008-06-15 03:35:28’ order by pubtime asc Limit 1 Offset 0

貌似时间的格式有严格的要求 2008-06-15 03:35:28 前面只能用 - 后面只能用:不足二位数的补零

下一条:小于指定时间的第一条

select title,pubtime from article where pubtime<’2008-06-15 03:35:28’ order by pubtime desc Limit 1 Offset 0

注意时间的精度。03:35:28 后面就没有了。

03:35:28.000

sqlite 中函数--nullif()、ifnull()、strftime()及时间格式函数相关推荐

  1. vue 时间格式化函数_vue开发记录--通用时间格式函数

    parseTime(time, fm) { // 解析时间 time: 时间戳或者实践对象 fm: 格式 默认是{y}-{m}-{d} {h}:{i}:{s} if (arguments.length ...

  2. mysql 在时间上加120s_sqlserver 时间格式函数详细

    一.时间函数 在使用存储过程,sql函数的时候,会遇到一些对时间的处理.比如时间的获取与加减.这里就用到了sql自带的时间函数.下面我列出这些函数,方便日后记忆,使用. --getdate 获取当前时 ...

  3. 在java中如何把字符串转换成时间格式?

    在java中如何把字符串转换成时间格式? 检举 | 2007-11-28 17:26 提问者:baixiao429 | 悬赏分:20 | 浏览次数:6645次 有这样一个字符串:"20070 ...

  4. sqlserver 时间格式函数详细

    一.时间函数 在使用存储过程,sql函数的时候,会遇到一些对时间的处理.比如时间的获取与加减.这里就用到了sql自带的时间函数.下面我列出这些函数,方便日后记忆,使用. --getdate 获取当前时 ...

  5. c语言调用系统当前时间的函数,c语言获取系统当前时间的函数,求讲解?

    1.C语言中读取系统时间的函数为time(),其函数原型为: #include time_t time( time_t * ) ; time_t就是long,函数返回从1970年1月1日(MFC是18 ...

  6. php时间日期函数转字符串,php自定义时间转换函数示例

    本文实例讲述了php自定义时间转换函数.分享给大家供大家参考,具体如下: 我们可以把经常用到的函数封装起来,在抽象类中,然后继承来使用. /** * 时间转时间戳 * @param object $s ...

  7. MT4/MQL4入门到精通EA教程第八课-MQL语言常用函数(八)-常用时间功能函数

    时间功能函数详解 TimeCurrent(); //返回服务器当前时间 TimeDayOfWeek();//返回当前时间星期几 TimeGMT(); //返回GTM时间 TimeGMTOffset() ...

  8. Vue中导入DayJs(时间戳转时间格式)

    1.Npm安装Dayjs npm install dayjs --save 2.Dayjs写入到Vue原型中 import dayjs from 'dayjs'; Vue.prototype.$day ...

  9. perl 的 localtime、timelocal、strftime关于时间的函数

    timelocal()是从格式化的时间输入转换成秒:而localtime()是从秒转换成格式化的时间.返回的年份都是对1900的偏移值. timelocal用法如下: my $second_str = ...

最新文章

  1. context of your framing
  2. C#与Javascript变量、函数之间的相互调用2008年11月28日 星期五 05:28 P.M.1.如何在JavaScript访问C#函数?
  3. mybatis $和#源代码分析
  4. 类名 窗口句柄 结束进程
  5. GDB调试精粹及使用实例来源-转
  6. HDU1754 I Hate It (线段树单点修改+区间查询)
  7. Python3实现批量下载百度搜索图片
  8. 数学笔记——导数5(指数函数和对数函数的导数)
  9. sf授权php,授权系统全解源码(支持分子系统)【原完整版】
  10. 【Verilog基础】常见的加法器电路总结(面试常考)(半加器、全加器、行波进位加法器RCA、超前进位加法器CLA)
  11. CnOpenData中国上市公司全部公告数据
  12. 用Python玩转二维码
  13. 基于SpringBoot的简历管理系统
  14. oracle 10g express linux,使用Oracle10g express 版本方案介绍
  15. vim如何与外界复制粘贴
  16. 网页采集器-八爪鱼采集器
  17. 合泰HT32 淘晶驰TJC--T0串口屏学习笔记
  18. 读Spring的源代码五:AutoWired是如何实现注入的
  19. 基于R语言的Kaggle案例分析-泰坦尼克号
  20. RFID定位原理及优劣势(优缺点)解读

热门文章

  1. 洛谷P1125笨小猴C语言
  2. macOS 入门指南
  3. 计算机中什么符号代表除号,电脑怎么打除号?word除号怎么打出来?键盘上÷号是哪个键?除以符号电脑怎么打?...
  4. TDM与FDM的比较
  5. 如何添加计算机硬盘分区,怎么给电脑硬盘增加设置分区
  6. opencv05:图像的基本操作
  7. 深入理解WKWebView白屏
  8. 加州大学欧文分校计算机排名,2017年加州大学欧文分校在美国的排名是多少?...
  9. 测试开发3年,我决定去读个名校硕士
  10. AutoCAD2018_编辑工具