返回函数Android数据库开发之-SQLite 《函数大全》

发一下牢骚和主题无关:

    

SQLite 函数大全

    

    

abs(X) 返回参数X的绝对值。
coalesce(X,Y,...) 返回第一个非空参数的副本。若所有的参数均为NULL,返回NULL。至少2个参数。
glob(X,Y) 用于实现SQLite"X GLOB Y"语法。可应用 sqlite3_create_function() 重载该函数从而改变GLOB运算符的功能。
ifnull(X,Y) 返回第一个非空参数的副本。 若两个参数均为NULL,返回NULL。与下面的 coalesce()相似。
last_insert_rowid() 返回以后数据库连接最后插入行的ROWIDsqlite_last_insert_rowid() API函数一样可用于失掉该值。
length(X) 返回X的长度,以字符计。如果SQLite被配置为支持UTF-8,则返回UTF-8字符数而不是字节数。
like(X,Y [,Z]) 用于实现SQL语法"X LIKE Y [ESCAPE Z]".若应用可选的ESCAPE子句,则函数被付与三个参数,否则只有两个。可应用sqlite3_create_function() 重载该函数从而改变LIKE运算符的功能。 注意同时重载like()的两参数和三参数版本,否则在应用/不应用 ESCAPE子句时,LIKE运算符的实现可能应用的是不同的代码。
lower(X) 返回X字符串的所有字符小写化版本。这一转换应用C语言库的tolower()函数,对UTF-8字符不能供给好的支持。
max(X,Y,...) 返回最大值。参数可以不仅仅为数字,可认为字符串。大小顺序由经常使用的排序法则决定。注意,max()在有2个或更多参数时为简单函数,但当仅给出一个参数时它变为聚集函数。
min(X,Y,...) 返回最小值。与max()相似。
nullif(X,Y) 当两参数不同时返回X,否则返回NULL.
quote(X) 返回参数的适于插入其它SQL语句中的值。字符串会被添加单引号,在内部的引号前会加入逃逸符号。 BLOB被编码为十六进制文本。以后的VACUUM应用这一函数实现。在应用触发器实现撤销/重做功能时这一函数也很有效。
random(*) 返回介于-2147483648+2147483647之间的随机整数。
round(X)
round(X,Y) X四舍五入,保留小数点后Y位。若忽略Y参数,则默许其为0
soundex(X) 盘算字符串Xsoundex编码。参数为NULL时返回字符串"?000".缺省的SQLite是不支持该函数的,当编译时选项 -DSQLITE_SOUNDEX=1 时该函数才可用。
sqlite_version(*) 返回所运行的SQLite库的版本号字符串。如 "2.8.0"
substr(X,Y,Z) 返回输入字符串X中以第Y个字符开始,Z个字符长的子串。 X最左端的字符序号为1。若Y为负,则从右至左数起。若SQLite配置支持UTF-8,则字符代表的是UTF-8字符而非字节。
typeof(X) 返回表达式X的类型。返回值可能为"null", "integer", "real", "text", 以及 "blob". SQLite的类型处理拜见SQLite3的数据类型.
upper(X) 返回X字符串的所有字符大写化版本。这一转换应用C语言库的toupper()函数,对UTF-8字符不能供给好的支持。

以下是缺省可用的聚集函数列表。可以应用C语言写出其它的聚集函数然后应用sqlite3_create_function() API函数添加到数据库引擎中。

在单参数聚集函数中,参数可以加前缀DISTINCT。这时重复参数会被过滤掉,然后才穿入到函数中。例如,函数"count(distinct X)"返回字段X的不重复非空值的个数,而不是字段X的全体非空值。

avg(X) 返回一组中非空的X的平均值。非数字值作0处理。avg()的结果老是一个浮点数,即使所有的输入变量都是整数。

count(X)
count(*) 返回一组中X是非空值的次数的第一种情势。第二种情势(不带参数)返回该组中的行数。
max(X) 返回一组中的最大值。大小由经常使用排序法决定。
min(X) 返回一组中最小的非空值。大小由经常使用排序法决定。仅在所有值为空时返回NULL
sum(X)
total(X) 返回一组中所有非空值的数字和。若没有非空行,sum()返回NULLtotal()返回0.0. NULL通常情况下并非对于没有行的和的一个有意义的结果,但SQL标准如此要求,且大部分其它SQL数据库引擎这样定义sum(),所以SQLite 也如此定义以保证兼容。我们供给非标准的total()函数作为处理该SQL语言计划问题的一个简易方法。

total()的返回值式中为浮点数。sum()可认为整数,当所有非空输入均为整数时,和是精确的。 若sum()的任意一个输入既非整数也非NULL或盘算中产生整数类型的溢出时,sum()返回接近真和的浮点数。

    

    

SQLite的日期时间函数

    

    

1.date(日期时间字符串, 修正符, 修正符, ……)

    

    

2.time(日期时间字符串, 修正符, 修正符, ……)
3.datetime(日期时间字符串, 修正符, 修正符, ……)
4.julianday(日期时间字符串, 修正符, 修正符, ……)
5.strftime(日期时间格式, 日期时间字符串, 修正符, 修正符, ……)

    

    上述五个函数需要一个日期时间字符串做参数,后面可以跟零到多个修正符参数。而 strftime() 函数还需要一个日期时间格式字符串做第一个参数。

    

1.date() 函数返回一个以 “YYYY-MM-DD” 为格式的日期;
2.time() 函数返回一个以 “YYYY-MM-DD HH:MM:SS” 为格式的日期时间;
3.julianday() 函数返回一个天数,从格林威治时间公元前4714年11月24号开始算起;
4.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() 函数来表现:
    每日一道理
当浮华给予我们过多欺骗,现实中的虚假几乎让我们忘却了真的存在,是真情唤回了迷离的心,是真情带给了我们最纯、最真的感觉,它流露的是美的誓言,渗透的是永恒执著的真爱。

    

1.date(…)         ->   strftime(“%Y-%m-%d”,…)
2.time(…)         ->   strftime(“%H:%M:%S”,…)
3.datetime(…)     ->   strftime(“%Y-%m-%d %H:%M:%S”,…)
4.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。

    

修正符,日期和时间可以应用下面的修正符来变动日期或时间:

    

NNN days
NNN hours
NNN minutes
NNN.NNNN seconds
NNN months
NNN years
start of month
start of year
start of week
start of day
weekday N
unixepoch
localtime
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');

    

    

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是产生当初的时间。

    

举个例子:
select date('2006-10-17','+1 day','+1 year');
结果:2007-10-18

    

strftime()函数可以把YYYY-MM-DD HH:MM:SS格式的日期字符串转换成其它情势的字符串。
strftime()的语法是strftime(格式, 日期/时间, 修正符, 修正符, ...)

    

举个例子:
select strftime('%Y.%m.%d %H:%M:%S','now','localtime');
结果:2006.10.17 21:41:09

    

在应用中发现SQLite不支持YYYY-MM-DD格式化,所以应用了strftime来处理。

    

SQLite内建函数表

    

算术函数
abs(X)
返回给定数字表达式的绝对值。
max(X,Y[,...])
返回表达式的最大值。
min(X,Y[,...])
返回表达式的最小值。
random(*)
返回随机数。
round(X[,Y])
返回数字表达式并四舍五入为指定的长度或精度。
字符处理函数
length(X)
返回给定字符串表达式的字符个数。
lower(X)
将大写字符数据转换为小写字符数据后返回字符表达式。
upper(X)
返回将小写字符数据转换为大写的字符表达式。
substr(X,Y,Z)
返回表达式的一部分。
randstr()

quote(A)

like(A,B)
确定给定的字符串是不是与指定的模式匹配。
glob(A,B)

条件判断函数
coalesce(X,Y[,...])

ifnull(X,Y)

nullif(X,Y)

集合函数
avg(X)
返回组中值的平均值。
count(X)
返回组中项目的数量。
max(X)
返回组中值的最大值。
min(X)
返回组中值的最小值。
sum(X)
返回表达式中所有值的和。
其他函数
typeof(X)
返回数据的类型。
last_insert_rowid()
返回最后插入的数据的ID。
sqlite_version(*)
返回SQLite的版本。
change_count()
返回受上一语句影响的行数。
last_statement_change_count()

文章结束给大家分享下程序员的一些笑话语录: 关于编程语言
如果 C++是一把锤子的话,那么编程就会变成大手指头。
如果你找了一百万只猴子来敲打一百万个键盘,那么会有一只猴子会敲出一 段 Java 程序,而其余的只会敲出 Perl 程序。
一阵急促的敲门声,“谁啊!”,过了 5 分钟,门外传来“Java”。
如果说 Java 很不错是因为它可以运行在所有的操作系统上,那么就可以说 肛交很不错,因为其可以使用于所有的性别上。

你可能感兴趣的:(android)