一.数学函数
功能 | 函数名 | 用法 |
绝对值 | ABS() | |
指数 | POWER() | POWER(FWeight,-0.5) |
平方根 | SQRT() | |
求随机数 | RAND() | |
舍入到最大整数 | CEILING() | |
舍入到最小整数 | FLOOR() | |
四舍五入 | ROUND(m) | |
四舍五入 | ROUND(m,d) | d是保留的小数位数 |
正弦 | SIN() | |
余弦 | COS () | |
反正弦 | ASIN() | |
反余弦 | ACOS() | |
正切 | TAN() | |
反正切 | ATAN() | |
2个变量的反正切 | ATAN2(X,Y) | Y是象限 |
余切 | COT() | |
圆周率 | PI() | |
弧度制转换为角度制 | DEGREES () | |
角度制转换为弧度制 | RADIANS () | |
求符号 | SIGN() |
大于0 则返回1,等于0 则返回0,小于0 则返回-1 |
求余数 | MOD() | |
自然对数 | LOG () | |
以10为底的对数 | LOG10() | |
求幂 | POWER(X,Y) |
二.字符串函数
功能 | 函数名 | 用法 |
计算字符串长度 | LENGTH() | |
字符串转换为小写 | LOWER() | |
字符串转换为大写 | UPPER () | |
截去字符串左侧空格 | LTRIM() | |
截去字符串右侧空格 | RTRIM () | |
截去字符串两侧的空格 | TRIM () | |
取子字符串 | SUBSTRING(string,start_position,length) | |
计算子字符串的位置 | INSTR(string,substring) | |
从左侧开始取子字符串 | LEFT (string,length) | |
字符串替换 | REPLACE(string,string_tobe_replace,string_to_replace) | |
得到字符的ASCII码 | ASCII() | |
得到一个ASCII码数字对应的字符 | CHAR() | |
发音匹配度 | SOUNDEX() |
时间日期函数
功能 | 函数名 | 用法 |
取得当前日期时间 | NOW() | mysql |
日期增减 | DATE_ADD (date,INTERVAL expr type) | SELECT FBirthDay, DATE_ADD(FBirthDay,INTERVAL 1 WEEK) as w1, DATE_ADD(FBirthDay,INTERVAL 2 MONTH) as m2, DATE_ADD(FBirthDay,INTERVAL 5 QUARTER) as q5 FROM T_Person |
计算日期差额 | DATEDIFF(date1,date2) | |
计算一个日期是星期几 | DAYNAME(FBirthDay) | |
取得日期的指定部分 | DATE_FORMAT(date,format) |
三.类型转换
mysql
CAST(expression AS type)
CONVERT(expression,type)
类型 | 缩写 | 说明 |
BINARY | BINARY字符串 | |
CHAR | 字符串类型 | |
DATE | 日期类型 | |
DATETIME | 时间日期类型 | |
SIGNED INTEGER | SIGNED | 有符号整数 |
TIME | 时间类型 | |
UNSIGNED INTEGER | UNSIGNED | 无符号整数 |
oracle
TO_CHAR(expression,format); 将时间日期类型或者数值类型的数据转换为字符串
TO_DATE (expression,format); 将字符串转换为时间类型
TO_NUMBER (expression,format); 将字符串转换为数值类型
HEXTORAW() 将十六进制格式的数据转换为原始值
RAWTOHEX() 将原始值转换为十六进制格式的数据。
TO_MULTI_BYTE() 将字符串中的半角字符转换为全角字符
TO_SINGLE_BYTE() 将字符串中的全角字符转换为半角字符
四.空值处理
COALESCE ( expression,value1,value2……,valuen)
COALESCE()函数将会返回包括expression在内的所有参数中的第一个非空表达式。如果expression不为空值则返回 expression;否则判断value1是否是空值,如果value1不为空值则返回value1;否则判断value2是否是空值,如果 value2不为空值则返回value3;……以此类推,如果所有的表达式都为空值,则返回NULL。
COALESCE()函数的简化版
MYSQL: IFNULL(expression,value)
Oracle: NVL(expression,value)
NULLIF ( expression1 , expression2 )
如果两个表达式不等价,则NULLIF 返回第一个expression1的值。如果两个表达式等价,则NULLIF 返回第一个expression1类型的空值。也就是返回类型与第一个expression相同。
CASE函数
SELECT
FName,
(CASE FName
WHEN ‘Tom’ THEN ‘GoodBoy’
WHEN ‘Lily’ THEN ‘GoodGirl’
WHEN ‘Sam’ THEN ‘BadBoy’
WHEN ‘Kerry’ THEN ‘BadGirl’
ELSE ‘Normal’
END) as isgood
FROM T_Person
SELECT
FName,
FWeight,
(CASE
WHEN FWeight<40 THEN ‘thin’
WHEN FWeight>50 THEN ‘fat’
ELSE ‘ok’
END) as isnormal
FROM T_Person
五.各数据库系统独有函数
1.MYSQL中的独有函数
IF()函数
SELECT FName, FWeight,
IF(FWeight>50,’太胖’,‘正常’) AS ISTooFat
FROM T_Person
CONV()函数用于对数字进行进制转换,比如将十进制的26转换为2进制显示,其参数格式如下:
CONV(N,from_base,to_base)
将每个人的体重四舍五入为整数,然后以二进制的形式显示它们:
SELECT FWeight,Round(FWeight),
CONV(Round(FWeight),10,2)
FROM T_Person
填充函数
LPAD(str,len,padstr)
RPAD(str,len,padstr)
SELECT FName,LPAD(FName,5,’*‘),RPAD(FName,5,’*‘) FROM T_Person
REPEAT()用来得到一个子字符串重复了若干次所组成的字符串
REPEAT(str,count)
字符串颠倒
REVERSE() 函数用来将一个字符串的顺序颠倒
字符串的集合操作
SELECT FName,
ELT(FLevel, ‘VIP客户’, ‘高级客户’, ‘普通客户’)
FROM T_Customer
SELECT FName,
FIELD(FCustomerTypeName, ‘VIP’, ‘会员’, ‘普通客户’)
FROM T_Customer
计算集合中的最大最小值
SELECT GREATEST(2,7,1,8,30,4,3,99,2,222,12),
LEAST(2,7,1,8,30,4,3,99,2,222,12)
辅助功能函数
DATABASE()函数返回当前数据库名;
VERSION()函数以一个字符串形式返回MySQL 服务器的版本;
USER()函数(这个函数还有SYSTEM_USER、SESSION_USER两个别名)返回当前MySQL 用户名。
ENCODE(str,pass_str)函数使用pass_str 做为密钥加密str,函数的返回结果是一个与string 一样长的二进制字符。如果希望将它保存到一个列中,需要使用BLOB列类型。
DECODE()函数使用pass_str 作为密钥解密经ENCODE加密后的字符串crypt_str。
MD5(string)、SHA1(string)两个函数就是分别用来使用MD5算法和SHA1算法来进行字符串的摘
要计算的函数
2.Oracle中的独有函数
填充函数
SELECT FName,
LPAD(FName,5,’*‘),
RPAD(FName,5,’#‘)
FROM T_Person
返回当月最后一天
SELECT FName,FBirthDay,
LAST_DAY(FBirthDay)
FROM T_Person
WHERE FBirthDay IS NOT NULL
计算最大最小值
SELECT GREATEST(2,7,1,8,30,4,5566,99,2,222,12),
LEAST(2,7,1,8,30,4,3,99,-2,222,12)
FROM DUAL
辅助功能函数
取得当前登录用户名,注意,不能用括号
SELECT USER
FROM DUAL
USERENV()函数用来取得当前登录用户相关的环境信息
参数 | 说明 |
‘ISDBA’ | 如果当前登录用户有DBA的角色则返回TRUE,否则返回FALSE |
‘LANGUAGE’ | 返回当前登录用户使用的语言和字符集,返回格式为“语言.字符集” |
‘TERMINAL’ | 返回当前登录用户的操作系统标识 |
‘SESSIONID’ | 返回当前登录用户的会话标识 |
‘ENTRYID’ | 返回当前登录用户的认证标识 |
‘LANG’ | 返回当前用户使用的语言,它比’LANGUAGE’的返回值短 |
‘INSTANCE’ | 返回当前实例的标识 |
SELECT USERENV(‘ISDBA’) AS ISDBA,
USERENV(‘LANGUAGE’) AS LANGUAGE,
USERENV(‘LANG’) AS LANG
FROM DUAL