一、日期和时间函数:原文地址
SQLite主要支持以下四种与日期和时间相关的函数,如:
1). date(timestring, modifier, modifier, ...)
2). time(timestring, modifier, modifier, ...)
3). datetime(timestring, modifier, modifier, ...)
4). strftime(format, timestring, modifier, modifier, ...)
以上所有四个函数都接受一个时间字符串作为参数,其后再跟有0个或多个修改符。其中strftime()函数还接受一个格式字符串作为其第一个参数。strftime()和C运行时库中的同名函数完全相同。至于其他三个函数,date函数的缺省格式为:"YYYY-MM-DD",time函数的缺省格式为:"HH:MM:SS",datetime函数的缺省格式为:"YYYY-MM-DD HH:MM:SS"。
1. strftime函数的格式信息:
格式 |
说明 |
%d |
day of month: 00 |
%f |
fractional seconds: SS.SSS |
%H |
hour: 00-24 |
%j |
day of year: 001-366 |
%J |
Julian day number |
%m |
month: 01-12 |
%M |
minute: 00-59 |
%s |
seconds since 1970-01-01 |
%S |
seconds: 00-59 |
%w |
day of week 0-6 with Sunday==0 |
%W |
week of year: 00-53 |
%Y |
year: 0000-9999 |
%% |
% |
需要额外指出的是,其余三个时间函数均可用strftime来表示,如:
date(...) strftime('%Y-%m-%d', ...)
time(...) strftime('%H:%M:%S', ...)
datetime(...) strftime('%Y-%m-%d %H:%M:%S', ...)
2. 时间字符串的格式:
见如下列表:
1). YYYY-MM-DD
2). YYYY-MM-DD HH:MM
3). YYYY-MM-DD HH:MM:SS
4). YYYY-MM-DD HH:MM:SS.SSS
5). HH:MM
6). HH:MM:SS
7). HH:MM:SS.SSS
8). now
5)到7)中只是包含了时间部分,SQLite将假设日期为2000-01-01。8)表示当前时间。
3. 修改符:
见如下列表:
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 day
10).weekday N
1)到6)将只是简单的加减指定数量的日期或时间值,如果NNN的值为负数,则减,否则加。7)到9)则将时间串中的指定日期部分设置到当前月、年或日的开始。10)则将日期前进到下一个星期N,其中星期日为0。注:修改符的顺序极为重要,SQLite将会按照从左到右的顺序依次执行修改符。
二、其它函数
函数 |
说明 |
avg(x) |
该函数返回在同一组内参数字段的平均值。对于不能转换为数字值的String和BLOB类型的字段值,如'HELLO',SQLite会将其视为0。avg函数的结果总是浮点型,唯一的例外是所有的字段值均为NULL,那样该函数的结果也为NULL。 |
count(x|*) |
count(x)函数返回在同一组内,x字段中值不等于NULL的行数。count(*)函数返回在同一组内的数据行数。 |
group_concat(x[,y]) |
该函数返回一个字符串,该字符串将会连接所有非NULL的x值。该函数的y参数将作为每个x值之间的分隔符,如果在调用时忽略该参数,在连接时将使用缺省分隔符","。再有就是各个字符串之间的连接顺序是不确定的。 |
max(x) |
该函数返回同一组内的x字段的最大值,如果该字段的所有值均为NULL,该函数也返回NULL。 |
min(x) |
该函数返回同一组内的x字段的最小值,如果该字段的所有值均为NULL,该函数也返回NULL。 |
sum(x) |
该函数返回同一组内的x字段值的总和,如果字段值均为NULL,该函数也返回NULL。如果所有的x字段值均为整型或者NULL,该函数返回整型值,否则就返回浮点型数值。最后需要指出的是,如果所有的数据值均为整型,一旦结果超过上限时将会抛出"integer overflow"的异常。 |
total(x) |
该函数不属于标准SQL,其功能和sum基本相同,只是计算结果比sum更为合理。比如当所有字段值均为NULL时,和sum不同的是,该函数返回0.0。再有就是该函数始终返回浮点型数值。该函数始终都不会抛出异常。 |
函数 |
说明 |
abs(X) |
该函数返回数值参数X的绝对值,如果X为NULL,则返回NULL,如果X为不能转换成数值的字符串,则返回0,如果X值超出Integer的上限,则抛出"Integer Overflow"的异常。 |
changes() |
该函数返回最近执行的INSERT、UPDATE和DELETE语句所影响的数据行数。我们也可以通过执行C/C++函数sqlite3_changes()得到相同的结果。 |
coalesce(X,Y,...) |
返回函数参数中第一个非NULL的参数,如果参数都是NULL,则返回NULL。该函数至少2个参数。 |
ifnull(X,Y) |
该函数等同于两个参数的coalesce()函数,即返回第一个不为NULL的函数参数,如果两个均为NULL,则返回NULL。 |
length(X) |
如果参数X为字符串,则返回字符的数量,如果为数值,则返回该参数的字符串表示形式的长度,如果为NULL,则返回NULL。 |
lower(X) |
返回函数参数X的小写形式,缺省情况下,该函数只能应用于ASCII字符。 |
ltrim(X[,Y]) |
如果没有可选参数Y,该函数将移除参数X左侧的所有空格符。如果有参数Y,则移除X左侧的任意在Y中出现的字符。最后返回移除后的字符串。 |
max(X,Y,...) |
返回函数参数中的最大值,如果有任何一个参数为NULL,则返回NULL。 |
min(X,Y,...) |
返回函数参数中的最小值,如果有任何一个参数为NULL,则返回NULL。 |
nullif(X,Y) |
如果函数参数相同,返回NULL,否则返回第一个参数。 |
random() |
返回整型的伪随机数。 |
replace(X,Y,Z) |
将字符串类型的函数参数X中所有子字符串Y替换为字符串Z,最后返回替换后的字符串,源字符串X保持不变。 |
round(X[,Y]) |
返回数值参数X被四舍五入到Y刻度的值,如果参数Y不存在,缺省参数值为0。 |
rtrim(X[,Y]) |
如果没有可选参数Y,该函数将移除参数X右侧的所有空格符。如果有参数Y,则移除X右侧的任意在Y中出现的字符。最后返回移除后的字符串。 |
substr(X,Y[,Z]) |
返回函数参数X的子字符串,从第Y位开始(X中的第一个字符位置为1)截取Z长度的字符,如果忽略Z参数,则取第Y个字符后面的所有字符。如果Z的值为负数,则从第Y位开始,向左截取abs(Z)个字符。如果Y值为负数,则从X字符串的尾部开始计数到第abs(Y)的位置开始。 |
total_changes() |
该函数返回自从该连接被打开时起,INSERT、UPDATE和DELETE语句总共影响的行数。我们也可以通过C/C++接口函数sqlite3_total_changes()得到相同的结果。 |
trim(x[,y]) |
如果没有可选参数Y,该函数将移除参数X两侧的所有空格符。如果有参数Y,则移除X两侧的任意在Y中出现的字符。最后返回移除后的字符串。 |
upper(X) |
返回函数参数X的大写形式,缺省情况下,该函数只能应用于ASCII字符。 |
typeof(X) |
返回函数参数数据类型的字符串表示形式,如"Integer、text、real、null"等。
|
分享到:
相关推荐
这个版本在当时可能包含了性能优化、新的SQL函数或者对原有功能的改进。 sqlite-jdbc是Java语言连接SQLite数据库的驱动,允许Java应用程序通过JDBC接口与SQLite进行交互。版本3.7.15-M1是该驱动的一个特定构建,...
它支持所有的SQL标准,包括创建数据库、表,定义字段,以及复杂的查询语法,如JOIN、子查询和聚合函数。 使用"sqlite3.exe",你可以按照以下步骤操作: 1. **安装与运行**:解压"sqlite-shell-win32-x86-3080200....
1. **sqlite3.def**:这是一个DEF文件,通常用于定义DLL导出的函数和变量。它包含了SQLite3 DLL对外提供的接口,使得其他程序可以调用这些接口进行数据库操作,如打开、关闭数据库,执行SQL语句等。 2. **sqlite3....
我们需要查看关键函数,如创建快照、恢复快照的实现。 3. **API设计**:项目可能提供了一套API供其他程序调用,这些API可能包括初始化、创建、读取和管理SQLite数据库的快照。通过分析API的设计,我们可以理解其...
2. **sqlite3.def**:这个文件是SQLite动态链接库(DLL)的定义文件,用于导出SQLite库中的函数,供其他程序调用。在Windows环境中,如果需要将SQLite集成到其他应用程序中,可以使用这个文件来生成相应的DLL。 3. ...
同时,为了正确地使用SQLite3.dll,开发者需要了解如何在C/C++或者其他支持DLL的语言中进行API调用,例如使用`LoadLibrary`和`GetProcAddress`函数获取并执行SQLite的函数。 总的来说,"sqlite-dll-win64-x64"是一...
7. **虚拟表和函数**:SQLite3支持虚拟表,允许你使用非传统方式存储和访问数据,如SQLite FTS(全文搜索)和RTree(空间索引)。此外,还可以定义自定义函数来扩展其功能。 8. **性能优化**:通过创建索引、合理...
2. 新的SQL功能:可能添加了新的SQL函数或者对现有函数进行了增强,例如窗口函数、JSON支持或更好的事务处理能力。 3. 安全性增强:可能修复了一些已知的安全漏洞,确保数据的安全性和隐私。 4. 兼容性提升:可能...
4. sqlite3.h:这是SQLite的头文件,包含了所有必要的函数声明和数据结构定义,供外部程序调用SQLite API。 5. sqlite3ext.h:这是SQLite的扩展API头文件,用于编写自定义的VFS(虚拟文件系统)、虚拟表模块、函数...
- 开发者可以使用生成的SQLite库来连接和操作数据库,例如,在C/C++中,可以使用sqlite3_open()函数打开数据库,sqlite3_exec()执行SQL命令,sqlite3_prepare_v2()和sqlite3_step()处理预编译的语句等。 总之,...
- `sqlite3.h`:这是SQLite的公共接口头文件,包含了所有用于与SQLite交互的函数声明和数据结构定义。开发者在编写程序时需要包含此文件,以便调用SQLite API进行数据库操作。 - `sqlite3.c`:这是SQLite的主要源...
此外,SQLite支持多种数据类型,包括文本、数值、日期/时间以及二进制大对象(BLOB),并提供了丰富的SQL函数和操作。 SQLite的自动编译配置选项允许用户根据需求定制构建,例如禁用某些不必要或不安全的功能,或者...
6. **扩展性**:开发者可以通过 VFS(Virtual File System)接口自定义存储层,或者编写 SQL 函数和虚拟表来扩展其功能。 7. **性能优化**:SQLite 使用了一些优化技术,如索引、预编译语句和缓存策略,以提高查询...
7. 扩展功能:通过sqlite3ext.h,可以了解如何编写自定义的SQL函数和聚合函数,增强SQLite的功能。 总之,"sqlite-amalgamation-3140200" 提供了一个深入了解SQLite数据库引擎工作原理的机会,对于软件开发者来说,...
关于sqlite3.def文件,这是一个导出定义文件,它定义了sqlite3.dll对外暴露的函数接口。这些接口是开发者在使用SQLite API时会调用的,例如`sqlite3_open()`用于打开数据库,`sqlite3_exec()`用于执行SQL语句等。这...
10. 扩展函数:SQLite允许用户编写自定义的SQL函数,扩展其功能,如使用C语言编写并编译成动态链接库,然后通过sqlite3.load_extention加载。 总之,“sqlite-shell-win32-x86-3071300.zip”提供了在Windows环境下...
对于C语言,SQLite提供了一组函数,如`sqlite3_open()`、`sqlite3_exec()`、`sqlite3_prepare_v2()`等,用于打开数据库、执行SQL语句和处理结果集。 此外,SQLite还支持数据库备份、日志记录、触发器、视图、存储...
2. **新功能**:版本3170000可能引入了新的SQL函数、优化器改进、或者对特定数据类型的支持。例如,可能增加了对JSON操作的增强,或者提高了大数据集处理的性能。 3. **安全与稳定性**:任何版本更新都会重视安全性...
然后就可以通过调用`sqlite3_open()`等函数来创建、打开数据库,执行`sqlite3_exec()`进行SQL语句的执行,使用`sqlite3_prepare_v2()`和`sqlite3_step()`进行预编译语句的处理等。 总之,SQLite-amalgamation是...
在实际应用中,开发者通常会通过编程语言的SQLite驱动或者适配器(如Python的sqlite3模块,C#的System.Data.SQLite库等)来间接调用这些DLL中的函数,以便更方便地与SQLite交互。这样的接口通常会提供更高级别的抽象...