以前写SQL语句的时候用这些函数,过一段就忘了一些不经常用的,所以现在用一个就总结一个,把以前用的都找了下,
又发现好多自己以前没有用过的,所以分享出来大家看下。
sql server的几个函数要记录 注意匹配符:“%”为匹配任意长度任意字符,“_”匹配单个任意字符,
[A]匹配以A开头的,
[^A]匹配除开以A开头的。
1,统计函数 avg, count, max, min, sum
2,数学函数 ceiling
(n)
返回大于或者等于n的最小整数
floor(n),
返回小于或者是等于
n的最大整数
round(m,n), 四舍五入,n是保留小数的位数
abs(n)
绝对值sign(n),
当n>0,
返回1,
n=0,
返回0,
n<0,
返回-1
PI(), 3.1415....
rand(),rand(n),
返回
0-1
之间的一个随机数
3,字符串函数
ascii(), 将字符转换为
ASCII码, ASCII('abc') = 97
char(), ASCII 码
转换为字符
low(), upper() 大小写转换
str(a,b,c)转换数字为字符串。
a,是要转换的字符串。 b是转换以后的长度,
c是小数位数。
str(123.456,8,2) = 123.46
ltrim(), rtrim()
去空格
ltrim去左边的空格, rtrim去右边的空格
select LEFT('abcde',3) abc select SUBSTRING('abcdef',2,3)bcd
left(n), right(n), substring(str, start,length)
截取字符串charindex(子串,母串),查找是否包含。
返回第一次出现的位置,没有返回0
patindex('%pattern%', expression)
功能同上,可是使用通配符
replicate('char', rep_time),
重复字符串
reverse(char),
颠倒字符串
replace(str, strold, strnew)
替换字符串
space(n), 产生n个空行
stuff(), SELECT STUFF('abcdef', 2, 3, 'ijklmn') ='aijklmnef', 2是开始位置,3是要从原来串中删除的字符长度,ijlmn是要插入的字符串。
3,类型转换函数
: cast, cast( expression as data_type), Example: SELECT SUBSTRING(title, 1, 30) AS Title, ytd_sales FROM titles
WHERE CAST(ytd_sales AS char(20)) LIKE '3%'
convert(data_type, expression)
4,日期函数
day(), month(), year()
dateadd(datepart, number, date), datapart指定对那一部分加,
number知道加多少,
date指定在谁的基础上加。
datepart的取值包括,year,quarter,month,dayofyear,day,week,hour,minute,second,
比如明天
dateadd(day,1, getdate())
datediff(datepart,date1,date2). datapart和上面一样。整个函数结果是
date2 - date1
datename(datepart, date)
取那一部分,返回字符串。
datepart(datepart, date)
取一部分,返回整数。
getdate()当前时间
5,系统函数
col_length('tablename','colname')
col_name, SELECT COL_NAME(OBJECT_ID('Employees'), 1) =
EmployeeID
datalength, example: datalenght('abc') =3, datalength(pub_name) --列名