sqlite3日期时间格式化和自动输入

这篇具有很好参考价值的文章主要介绍了sqlite3日期时间格式化和自动输入。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

Sqlite3系列:初步💎where💎select

基础命令

sqlite中并未提供单独的日期时间类型,但提供了三种时间表示方式

  • 通过text来存储时间文本
  • 用整型来存储时间戳,时间戳是从1970-01-01算起的秒数
  • 用浮点型来存储自儒略日开始算起的天数,儒略日即公元前4713年1月1日中午12点。

并且提供了一些日期时间函数,

函数 返回值 格式
date(timestring, …) 日期 YYYY-MM-DD
time(timestring, …) 时间 HH:MM:SS
datetime(timestring, …) 日期时间 YYYY-MM-DD HH:MM:SS
julianday(timestring, …) 天数 自儒略日起算
strftime(format, timestring, …) 日期 format指定

简单示例如下

sqlite> select datetime('now');
2023-08-17 11:33:22
sqlite> select time('12:00');
12:00:00
sqlite> select date('2023-01-01');
2023-01-01

在未加修饰的情况下,日期格式只能YYYY-MM-DD,如果输入2023-1-1则并不会识别为日期。

修饰符

在timstring后面,可以接一些修饰符,以更改输出,共有三种类型。第一种是在当前时间的基础上做加减法,例如

sqlite> select date('2023-08-17', '-4 months', '1 days');
2023-04-18

表示2023年8月17日减去4个月,然后再加上1天。days可以换成months, years, hours, minutes以及seconds,其中秒数的运算支持浮点型。

第二种是根指定相对于当前时刻的比较特殊的时间,比如本月第一天,一共有四个修饰符,分别是start of month, start of year, start of day, weekday N,其中weekday表示当前时刻距离最近的下一个星期N对应的日期,示例如下

sqlite> select date('2023-08-17', 'weekday 2');
2023-08-22

表示2023年8月17日的下一个星期二是8月22日。

第三类用于指定时间格式,共有以下三种情况

unixepoch localtime utc
unix时间戳 本地时间 utc时间

格式化

strftime函数支持日期时间的格式化操作,

替换 描述 范围 替换 描述 范围
%j 年中日号 001-366 %d 月中日号 01-31
%W 年中周号 01-53 %w 周中日号 0-6
%J 儒略日数 DDDD.DDDD
%Y YYYY %m 00-12
%H 小时 00-23 %M 00-59
%f 带小数部分的秒 SS.SSS
%s 时间戳的秒数 %S 00-59
%% % symbol

其中,周日用0表示。

示例如下

sqlite> select strftime('今天是%Y年第%j天', 'now');
今天是2023年第229

自动输入时间

向数据库中输入日期时间和输入其他变量并没有区别,下面新建一个表,最后两列是日期时间,然后输入一组数据,效果如下。

sqlite> create table test(id int, name text, date, time);
sqlite> insert into test values(1, 'a', date('now'), time('now'));
sqlite> select * from test;
1|a|2023-08-17|11:56:04

但在sqlite3中,日期时间有更便捷的输入方式,只需在创建表的时候,为其添加一个默认的时间函数就可以了。

sqlite> create table dtTest([id] int, name text, [date] TimeStamp default (date('now')), [time] timeStamp default (time('now')));

这个表一共有4列,只有name是需要手动输入的文章来源地址https://www.toymoban.com/news/detail-741415.html

sqlite> insert into dtTest(name) values("a");
sqlite> insert into dtTest(name) values("b");
sqlite> select * from dtTest;
|a|2023-08-17|12:05:39
|b|2023-08-17|12:05:41

到了这里,关于sqlite3日期时间格式化和自动输入的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • JavaScript 日期和时间的格式化大汇总(收集)

    一、日期和时间的格式化 1、原生方法 1.1、使用 toLocaleString 方法 Date 对象有一个 toLocaleString 方法,该方法可以根据本地时间和地区设置格式化日期时间。例如:   toLocaleString 方法接受两个参数,第一个参数是地区设置,第二个参数是选项,用于指定日期时间格式和时区信息

    2024年02月08日
    浏览(54)
  • Java格式化日期,时间(三种方法,建议收藏)

    在java中String类格式化的方法,是静态format()用于创建格式化的字符串。 format(String format, Object... args) 新字符串使用本地语言环境,制定字符串格式和参数生成格式化的新字符串。 format(Locale locale, String format, Object... args) 使用指定的语言环境,制定字符串格式和参数生成格式化

    2024年02月15日
    浏览(45)
  • Windows bat 批处理 日期时间格式化

    有一个批处理脚本,脚本中根据当前日期,动态的生成日志文件, 如:当前是 2023年06月20日,我希望生成的日志文件名为:XX_20230620.log Windows 在批处理中 获取日期和时间的方式如下: echo %time% 输出的时间格式: HH:MM:SS.NN HH :时 MM :分 SS :秒 NN :厘秒(注意不是毫秒,1秒

    2024年02月11日
    浏览(70)
  • Flutter/Dart日期格式化及时间戳转换

    点击进入我的自建博客链接 Dart 获取当前时间,以及获取当前年、月、日等。 创建指定时间还可以直接从符合日期格式的字符串直接转换,如下。 日期字符串转为时间 日期时间转成时间戳 时间戳转日期时间 可以给某个时间增加或减少时间段(Duration)。

    2024年02月11日
    浏览(47)
  • 使用 uni-app 开发项目,日期和时间如何格式化?

    功能需求描述 在开发项目时,往往需要对从后端查询到的时间进行格式化,查到的时间格式一般都是 时间戳 ,一堆数字,这时候怎么转化成类似于  2023年8月15日 08:12:10  这样的格式? 在组件显示格式化后的日期 其实 uni-app 的官方拓展组件  uni-dateformat  就能实现这个需求

    2024年02月05日
    浏览(52)
  • 【Java 基础篇】Java日期和时间格式化与解析指南:SimpleDateFormat详解

    日期和时间在软件开发中经常被用到,无论是用于记录事件、计算时间间隔还是格式化日期以供用户友好的展示。Java 提供了强大的日期和时间处理工具,其中 SimpleDateFormat 类是一个重要的工具,用于格式化日期和时间,同时也支持解析日期和时间。本篇博客将深入探讨 Sim

    2024年02月09日
    浏览(59)
  • 工作6年了日期时间格式化还在写YYYY疯狂给队友埋雷

    前言 哈喽小伙伴们好久不见,今天来个有意思的雷,看你有没有埋过。 正文 不多说废话,公司最近来了个外地回来的小伙伴,在广州工作过6年,也是一名挺有经验的开发。 他提交的代码被小组长发现有问题,给打回了,原因是里面日期格式化的用法有问题,用的SimpleDate

    2024年02月12日
    浏览(42)
  • Java中日期时间格式化方法SimpleDateFormat和DateTimeFormatter使用完整示例及区别说明

    示例代码: 示例截图:  这里完整的用两种方法分别实现了日期和String的来回转换,鉴于SimpleDateFormat早已过时,且非线程安全,所以推荐大家首选使用DateTimeFormatter,用法基本都是差不多的。变化不大。但是DateTimeFormatter需要Java Level 8(8 - Lambdas, type annotations etc.),需留意。

    2023年04月09日
    浏览(40)
  • Python中f‘‘、str.format()和str%()的字符串格式化详解(2)------格式占位符的使用,日期、时间格式使用

    目录 四、 f\\\'\\\'、str.format()和str%()格式化表达式中格式占位符的使用 1、实现进制(或格式)的转换与冒号: 2、实现对象的字符串形式转换与感叹号! 3、为对象指定宽度或精度 4、对对象取百分比 5、为对象增加正号+或负号- 6、为对象增加标志(flags) 五、 f\\\'\\\'、str.format()和str%()格式化

    2024年02月04日
    浏览(48)
  • JS日期与字符串相互转换(时间格式化YYYY-MM-DD,Dayjs的使用)

    文章内容 文章链接 JS数组对象—— 根据日期进行排序 , 按照时间进行升序或降序排序 https://blog.csdn.net/XSL_HR/article/details/128579840?spm=1001.2014.3001.5501 JS日期时间格式化—— 数字日期转中文日期 (封装函数,dayjs转换时间格式) https://blog.csdn.net/XSL_HR/article/details/128607024?spm=100

    2024年01月18日
    浏览(73)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包