gpt4 book ai didi

sqlite - sqlite使用blob作为纪元日期时间

转载 作者:行者123 更新时间:2023-12-03 19:11:30 26 4
gpt4 key购买 nike

我试图决定什么是在sqlite中存储日期时间的最佳方法。日期将是一个纪元。
I've been reading on wiki about the 2038 problem (it's very much like the year 2000 problem).考虑到我在tutorialspoint上一直读到的内容:
来自https://www.tutorialspoint.com/sqlite/sqlite_data_types.htm
Tutorialspoint建议使用以下日期时间形式的数据类型。

SQLite没有用于存储日期和/或时间的单独存储类,但是SQLite能够将日期和时间存储为TEXT,REAL或INTEGER值。

但是,当我查看类型描述时,BLOB没有大小限制,并且表示将数据插入数据库时​​的情况。

BLOB值是数据的blob,存储时与输入时完全相同。
整数该值是一个有符号整数,根据值的大小存储在1、2、3、4、6或8个字节中。

我在教程上看到,他们建议将sqlite类型的INTEGER用于日期时间。但是考虑到2038年的问题,我想如果我专注于将来的证明,那么使用BLOB是一个更好的选择,因为BLOB并不像INTEGER那样依赖特定数量的字节。
我是数据库设计的新手,所以我想知道最好做什么?

最佳答案

正如所说的那样,整数最多可以是8个字节,即64位有符号整数。您的问题不是SQLite能够使用32位存储不受2038问题约束的值。您的问题将是从不受此问题限制的时间中检索时间,也就是说,除非您试图保护292,277,026,596年的问题。

不需要使用BLOB,并且无需增加BLOB和时间之间的转换的复杂性和附加处理。

如果您想存储当前时间或现在基于当前时间的时间,甚至可以使用SQLite本身来检索合适的值。

也许考虑以下几点:

DROP TABLE IF EXISTS timevalues;
/* Create the table with 1 column with a weird type and a default value as now (seconds since Jan 1st 1970)*/
CREATE TABLE IF NOT EXISTS timevalues (dt typedoesnotmatterthtamuch DEFAULT (strftime('%s','now')));
/* INSERT 2 rows with dates of 1000 years from now */
INSERT INTO timevalues VALUES
(strftime('%s','now','+1000 years')),
((julianday('now','+1000 years') - 2440587.5)*86400.0);
/* INSERT a row using the DEFAULT */
INSERT INTO timevalues (rowid) /* specify the rowid column so there is no need to supply value for the dt column */
VALUES ((SELECT count() FROM timevalues)+1 /* get the highest rowid + 1 */);
/* Retrieve the data rowid, the value as stored in the dt column and the dt column converted to a user friendly format */
SELECT rowid,*, datetime(dt,'unixepoch') AS userfriendly FROM timevalues;
/* Cleanup the Environment */
DROP TABLE IF EXISTS timevalues;


结果是:

enter image description here


您可能希望阅读 Date And Time Functions,例如对于strftime,julianday和现在
rowid是一个特殊的通常隐藏的列,适用于所有表,除非它是WITHOUT ROWID表。通常不会使用它,或者使用INTEGER PRIMARY KEY作为别名时


请参见 SQLite Autoincrement以了解有关rowid及其别名以及为什么不使用AUTOINCREMENT的信息。

类型的列类型请参见 Datatypes In SQLite Version 3关于为什么可以这样。

关于sqlite - sqlite使用blob作为纪元日期时间,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58419733/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com