sqlserver常用函数大全
admin
2023-05-23 23:04:48
0

一、字符串函数

datalength(Char_expr) 返回字符串包含字符数,但不包含后面的空格

substring(expression,start,length) 不多说了,取子串

right(char_expr,int_expr) 返回字符串右边int_expr个字符

left()

    返回character_expression 左起 integer_expression 个字符。

ltrim() 把字符串头部的空格去掉。

rtrim() 把字符串尾部的空格去掉。

str ([,length[, ]]) 把数值型数据转换为字符型数据

    length 指定返回的字符串的长度,decimal 指定返回的小数位数。如果没有指定长度,缺省的length 值为10, decimal 缺省值为0。

    当length 或者decimal 为负值时,返回NULL;

    当length 小于小数点左边(包括符号位)的位数时,返回length 个*;

    先服从length ,再取decimal ;

    当返回的字符串位数小于length ,左边补足空格。

upper(char_expr) 转为大写

lower(char_expr) 转为小写

space(int_expr) 生成int_expr个空格

replicate(char_expr,int_expr)复制字符串int_expr次

reverse(char_expr) 反转字符串

stuff(char_expr1,start,length,char_expr2) 将字符串char_expr1中的从

        start开始的length个字符用char_expr2代替

ltrim(char_expr) rtrim(char_expr) 取掉空格

ascii(char) char(ascii) 两函数对应,取ascii码,根据ascii码取字符

char() 将ASCII 码转换为字符。如果没有输入0 ~ 255 之间的ASCII 码值,CHAR() 返回NULL 。

charindex(char_expr,expression) 返回char_expr的起始位置

patindex("%pattern%",expression) 返回指定模式的起始位置,否则为0


二、数学函数

trunc(45.923,1) 按指定精度截断十进制数 结果:45.9 此为oracle函数

mod(1600,300) 求除法余数 结果:100

abs(numeric_expr) 求绝对值

ceiling(numeric_expr) 取大于等于指定值的最小整数

avg(numeric_expr)取平均数

exp(float_expr) 取指数

floor(numeric_expr) 小于等于指定值得最大整数

pi() 3.1415926.........

power(numeric_expr,power) 返回power次方

rand([int_expr]) 随机数产生器

round(numeric_expr,int_expr) 安int_expr规定的精度四舍五入

sign(int_expr) 根据正数,0,负数,,返回+1,0,-1

sqrt(float_expr) 平方根


三、日期时间函数

getdate() 返回日期

getutcdate()  --获取utc时间

day(getdate())  --取出天

month(getdate())  --取出月

year(getdate())  --取出年

datename(datepart,date_expr) 返回名称如 June

datepart(datepart,date_expr) 取日期一部份

datediff(datepart,date_expr1.dateexpr2) 日期差

dateadd(datepart,number,date_expr) 返回日期加上 number

    上述函数中datepart的写法取值和意义:

        yy 1753-9999 年份

        qq 1-4 刻

        mm 1-12 月

        dy 1-366 日

        dd 1-31 日

        wk 1-54 周

        dw 1-7 周几

        hh 0-23 小时

        mi 0-59 分钟

        ss 0-59 秒

        ms 0-999 毫秒


四、系统其他函数

suser_name() 用户登录名

user_name() 用户在数据库中的名字

user 用户在数据库中的名字

show_role() 对当前用户起作用的规则

db_name() 数据库名

object_name(obj_id) 数据库对象名

col_name(obj_id,col_id) 列名

col_length(objname,colname) 列长度

valid_name(char_expr) 是否是有效标识符


五、类型转换函数

convert (数据类型[(长度)],表达式[,样式]) 

    将一种数据类型的表达式显式转换为另一种数据类型的表达式;

    长度:如果数据类型允许设置长度,可以设置长度,例如 varchar(10);

    样式:用于将日期类型数据转换为字符数据类型的日期格式的样式。


Style IDStyle 格式
100 或者 0mon dd yyyy hh:miAM (或者 PM)
101mm/dd/yy
102yy.mm.dd
103dd/mm/yy
104dd.mm.yy
105dd-mm-yy
106dd mon yy
107Mon dd, yy
108hh:mm:ss
109 或者 9mon dd yyyy hh:mi:ss:mmmAM(或者 PM)
110mm-dd-yy
111yy/mm/dd
112yymmdd
113 或者 13dd mon yyyy hh:mm:ss:mmm(24h)
114hh:mi:ss:mmm(24h)
120 或者 20yyyy-mm-dd hh:mi:ss(24h)
121 或者 21yyyy-mm-dd hh:mi:ss.mmm(24h)
126yyyy-mm-ddThh:mm:ss.mmm(没有空格)
130dd mon yyyy hh:mi:ss:mmmAM
131dd/mm/yy hh:mi:ss:mmmAM


    例如:

    CONVERT(VARCHAR(19),GETDATE())            返回:Dec 29 2008 11:45 PM

    CONVERT(VARCHAR(10),GETDATE(),110)     返回:12-29-2008

    CONVERT(VARCHAR(11),GETDATE(),106)     返回:29 Dec 08

    CONVERT(VARCHAR(24),GETDATE(),113)     返回:29 Dec 2008 16:25:46.635


cast (表达式 AS 数据类型[(长度)])

    将一种数据类型的表达式显式转换为另一种数据类型的表达式。

    例如:select cast(123 as nvarchar) 返回123

    select N'年龄:' + cast(23 as nvarchar) 返回 年龄:23


六、系统函数

newid() 无参数 

    返回一个GUID(全局唯一表示符)值

    例如:select newid()

    返回:2E6861EF-F4DB-4FFE-86EB-637482FE982J2

isnumeric (任意表达式)

    判断表达式是否为数值类型或者是否可以转换成数值。

    是:返回1,不是:返回0

    例如:select isnumeric(1111) 返回 1

    select isnumeric('123rr') 返回 0

    select isnumeric('123') 返回 1

isnull (任意表达式1,任意表达式2) 

    如果任意表达式1不为NULL,则返回它的值;否则,在将任意表达式2的类型转换为任意表达式1的类型(如果这两个类型不同)后,返回任意表达式2的值。

    例如:select isnull(null,N'没有值') 返回 没有值

    select isnull(N'具体的值',N'没有值') 返回 具体的值

isdate (任意表达式)

    确定输入表达式是否为有效日期或可转成有效的日期;

    是:返回1,不是:返回0

    例如:select isdate(getdate()) 返回1

    select isdate('2013-01-02') 返回1

    select isdate('198') 返回0


七、排名函数

row_number 无参数

    为结果集内每一行进行编号,从1开始后面行依次加1,常用于产生序号;

    例如:select row_number() over(order by userid desc) as [NO],username,password from T_USER


八、聚合函数

count()

    返回组中的总条数,count(*)返回组中所有条数,包括NULL值和重复值项,如果抒写表达式,则忽略空值,表达式为任意表达式。

max()

    返回组中的最大值,空值将被忽略,表达式为数值表达式,字符串表达式,日期。

min()

    返回组中的最小值,空值将被忽略,表达式为数值表达式,字符串表达式,日期。

sum()

    返回组中所有值的和,空值将被忽略,表达式为数据表达式。

avg()

    返回组中所有值的平均值,空值将被忽略,表达式为数据表达式。


上一篇:lamp wordpress

下一篇:MySQL创建数据库失败

相关内容

热门资讯

德瑞斯电子取得新型散热风扇专利... 国家知识产权局信息显示,深圳市德瑞斯电子科技有限公司取得一项名为“一种新型散热风扇”的专利,授权公告...
新兴技术及应用产业日报(05.... 公司动态 中国移动段晓东:6G智能体通信——智能经济发展新范式 中国移动研究院副院长段晓东在...
2026年618购机指南:50... 随着618购物节的临近,许多消费者都在寻找一款预算在5000元左右,既能满足日常高强度拍照需求,又无...
体育博物馆如何在互联网时代维持... 上海体育博物馆正在利用更多科技与智能,让游客能够沉浸式逛展。 博物馆如何在当今人工智能盛行的互联网时...
万斯大型失忆现场:呼吁投票反对... 美国副总统JD・万斯近日深陷网络群嘲。他呼吁支持者“投票反对华盛顿疯狂的领导层”,似乎忘了如今是谁在...
原创 在... NASA的气候模拟研究显示:40 亿年前,太阳刚形成不久,亮度只有现在的70%,整个太阳系比现在凉爽...
24岁演员,骑机车意外离世 近日,24岁短剧男演员黄子仟被曝离世,好友任九晗发文悼念,称从没想过再次见面,是看着你从冷柜里被抬出...
800元免费领,让养老院“头疼... “没想到,都快5月了,在我们这么大的社区,我是第一个申领养老消费券的人。”4月下旬,在90多岁父亲出...
方太燃气灶打不上火是什么原因? 可能是燃气灶 没有开燃气阀,有的时候是忘记开燃气阀门了;可能是燃气灶喷嘴堵塞,影响喷嘴点燃燃气;还可...
带熄火保护的燃气灶不出气怎么办 开启开关出现了故障,如果是带熄火保护的燃气灶由于使用年限过长,导致出现问题,则意味着无法正常进行使用...