本文主要介绍SQL SERVER数据库中一些常用的系统函数及其SQL SERVER 2005以上支持的开窗函数。

1.常用函数

--从字符串右边截取指定字符数

select RIGHT('HELLO', 2)   --LO

--受影响的行数

select @@ROWCOUNT

--求绝对值ABS()

SELECT ABS(-2.0)   --2.0

--计算指数的函数POWER()

, 0.5)

, 3)

--求平方根SQRT()

SELECT SQRT(64.02)

--取随机数,返回到之间的随机浮点值Rand()

SELECT Rand()

--将字符串转换为小写LOWER()

SELECT LOWER('HELLO WORLD')

--将字符串转换为大写UPPER()

SELECT UPPER(LOWER('HELLO WORLD'))

--取ASCII码ASCII()

SELECT ASCII('A')   --65

--取对应ASCII码的字符CHAR()

SELECT CHAR(ASCII('A'))   --A

--日期时间函数

--获取当前时间

SELECT GETDATE()

--获取日期部分

), GETDATE(), 101)  --03/11/2014

--获取时间部分

), GETDATE(), 108)  --17:00:10

--获取某个日期是礼拜几

SELECT DATENAME(WEEKDAY, GETDATE())

--返回guid,位的唯一值

select Newid()

--若P1非空,返回P1;否则,返回default默认值

COALESCE(P1,default)

COALESCE(P.FName, '没有开单人')

--返回当前所用语言名称

select @@language

--返回允许同时进行的最大用户连接数

select @@MAX_CONNECTIONS

--返回本地sql server的名称

select @@SERVERNAME

--返回当前安装的sql server的日期,版本和处理器类型

print @@VERSION

--确定输入的表达式是否为有效的日期

select ISDATE('2014-03-17')

), 123.00)+'abc'  --123.00abc

))+'abc'  --123.00abc

select cast('abc' as int)  --转换出错

select @@ERROR   --结果为,返回执行上一个sql语句的错误号,若没有错误,结果为

2.开窗函数

可以看到与聚合函数不同的是,开窗函数在聚合函数后增加了一个 OVER 关键字。开窗函数的调用格式为: 函数名(列) OVER(选项)   OVER 关键字表示把函数当成开窗函数而不是聚合函数。SQL 标准允许将所有聚合函数用做开窗函数,使用 OVER 关键字来区分这两种用法。

开窗函数 COUNT(*) OVER()对于查询结果的每一行都返回所有符合条件的行的条数。OVER 关键字后的括号中还经常添加选项用以改变进行聚合运算的窗口范围。如果 OVER 关键字后的括号中的选项为空,则开窗函数会对结果集中的所有行进行聚合运算。

SELECT FCITY , FAGE , 的所有记录数。

--ROW_NUMBER() OVER返回按某种规则排序后的某行的行数,只有SQL SERVER 2005以上支持

select * from (select ROW_NUMBER() OVER(ORDER BY UserID DESC) as RowNum, * FROM Tse_User) as A

WHERE A.RowNum >= 3 AND A.RowNum <= 4

-COUNT(0) OVER(), 统计总数

) OVER() from dbo.T_Reader where fage > 30

--COUNT(0) OVER(PARTITION BY fyearofbirth), 统计某个分区的数量

) OVER(PARTITION BY fage) FROM T_Reader

--Rank()遇相同的编号顺延,DENSE_RANK()遇相同的编号不变

select *, RANK() over(order by fage),

DENSE_RANK() over(order by fage),

ROW_NUMBER() over(order by fage) from t_reader

--按年龄排序,分成份,并计算每行对应的编号

) over(order by fsalary) from t_reader

--通过分区函数实现计算某个产品的销售量在同类产品总销售量中所占百分比

select T_Merchandise.FName, T_SaleBillDetail.FCount,

T_SaleBillDetail.FCount*1.0/SUM(T_SaleBillDetail.FCount) over(partition by T_Merchandise.FName) from

T_SaleBillDetail inner join T_Merchandise

on T_SaleBillDetail.FMerchandiseId = T_Merchandise.FId

如果您有什么问题,欢迎在下面评论,我们一起讨论,谢谢~

如果您觉得还不错,不妨点下右下方的推荐,有您的鼓励我会继续努力的~

[SQL SERVER系列]之常用函数和开窗函数介绍及实例的更多相关文章

  1. SQL Server进阶(八)查询——开窗函数、四大排名函数、透视数据、逆透视数据

    概述 ROW_NUMBER() OVER(PARTITION BY CustId ORDER BY ID DESC) https://www.jb51.net/article/75533.htm 开窗 ...

  2. SQL Server系列

    这里整理了我学习SQL Server的全部文章,包括从基础到高级,做一个目录,方便以后查找. SQL Server数据类型 SQL Server中开发常用的数据类型 单表查询和多表查询 一个单表查询的 ...

  3. Sql Server中不常用的表运算符之APPLY(2)

    在Sql Server中不常用的表运算符之APPLY(1)中提到,SQL2005中新支持的APPLY的特性:1.可以直接将表表达式(表值函数或者子查询)作为APPLY语句的右表连接左表.2.由于使用A ...

  4. SQL Server中,常用的全局变量

    在SQL Server中,全局变量是一种特殊类型的变量,服务器将维护这些变量的值.全局变量以@@前缀开头,不必进行声明,它们属于系统定义的函数.下表就是SQL Server中一些常用的全局变量. 全局 ...

  5. hive常用函数 wordCount--Hive窗口函数1.1.1 聚合开窗函数聚合开窗函数实战

    第三天笔记 第三天笔记 SQL练习Hive 常用函数关系运算数值计算条件函数日期函数重点!!!字符串函数Hive 中的wordCount1.1 Hive窗口函数1.1.1 聚合开窗函数聚合开窗函数实战 ...

  6. SQL Server 系列文章快速导航(SWF版)

    一.前言 在博客园写博客不自不觉已经有5个年头了,一开始只是为了记录工作中遇到的问题和解决办法,后来写的文章不自不觉的侧重在SQL Server方面的技术文章,在2014年1月终于鼓起勇气申请了微软S ...

  7. Sql Server中不常用的表运算符之UNPIVOT

    在Sql Server中不常用的表运算符之PIVOT中,介绍了PIVOT表运算符,现在来说说与之相对应的另一个表运算符UNPIVOT. 从名字可以看出,这个运算符的作用与PIVOT刚好相反,是将一行的 ...

  8. Microsoft SQL Server 管理 (常用管理及维护命令)

    --查询当前连接的实例名 select @@servername --察看任何数据库属性 sp_helpdb master --设置单用户模式,同时立即断开所有用户 alter database No ...

  9. SQL Server系列文章目录

    SQL Server系列文章目录SQL Server系列文章目录SQL Server系列文章目录SQL Server系列文章目录

随机推荐

  1. css3 渐变记

    css3 渐变 线性渐变 径向渐变 重复线性渐变 重复径向渐变 线性渐变 线性渐变接受三个参数,渐变的方向,起始颜色,结束颜色. 标准语法及参数:linear-gradient:([[<angl ...

  2. 使用spring+mybatis+atomikos+tomcat构建分布式事务

    本文通过一个demo,介绍如何使用spring+mybatis+atomikos+tomcat构建在一个事务中涉及两个数据源的web应用. demo功能:实现一个能成功提交和回滚的涉及两个数据库数据源 ...

  3. HTTP相关知识 --转载

    转载之,言简意赅

  4. 使用WDS安装Windows8.1

    WDS的部署 安装角色 配置 1. 选择配置服务器 2. 核对是否满足要求 3. 输入远程安装文件夹的路径 4. 选择是否使用自带的DHCP服务器 5. 可以保持默认 6. 完成配置后添加映像文件 7 ...

  5. iOS动画——弹窗动画(pop动画)

    用pop动画简单实现弹窗的缩放和渐变,感觉这个动画常用,就写一下博客 pop动画是Facebook推出的动画引擎,请自行到GitHub上搜索下载拖拽导入xcode项目中. 更多pop动画使用和原理可网 ...

  6. java新手笔记30 集合

    1.set/list package com.yfs.javase; import java.util.ArrayList; import java.util.Collection; import j ...

  7. 关于IE8以上 不引人css 症状

    不知道各位有没有体验过 这样的状况  在同一个文件夹中 <!DOCTYPE html> <html> <head> <meta charset="u ...

  8. emacs_1

    --> 正在处理依赖关系 perl(VMS::Filespec),它被软件包 perl-PathTools-3.2701-1.el5.rf.x86_64 需要---> 软件包 perl-p ...

  9. Poj 3239 Solution to the n Queens Puzzle

    1.Link: http://poj.org/problem?id=3239 2.Content: Solution to the n Queens Puzzle Time Limit: 1000MS ...

  10. Traveller项目技术资料

    Spring Spring PecClinic:Spring官方的宠物医院项目 it.zhaozhao.info/archives/63818:SPRING JPA入门 Spring Data RES ...