SQL统计计算

作者:管理员 发布时间:2020-12-25 13:24

我们不提倡使用SQL进行任何运算类的操作,因为这并非数据库所擅长的,性能消耗也比较大;

如有必要业务场景,需要统计数据,SQL也提供了一些函数,使用方法很简单,直接把列名扩起来就行了,如:

SELECT 列名1,AVG(列名1) FROM 表名

这样,查询出的结果,就新增了一列,为平均数,新列没有名字,可以用as设置名字

SELECT 列名1,AVG(列名1) as '平均数' FROM 表名  

相关函数列表如下:

统计函数

AVG(表达式) 返回表达式中所有的平均值。仅用于数字列并自动忽略NULL值。
COUNT(表达式) 返回表达式中非NULL值的数量。可用于数字和字符列。
COUNT(*) 返回表中的行数(包括有NULL值的列)。
MAX(表达式) 返回表达式中的最大值,忽略NULL值。可用于数字、字符和日期时间列。
MIN(表达式) 返回表达式中的最小值,忽略NULL值。可用于数字、字符和日期时间列。
SUM(表达式) 返回表达式中所有的总和,忽略NULL值。仅用于数字列。


数据科学计算

ABS(num_expr) 返回数值表达式的绝对值。
ACOS(float_expr) 返回角(以弧度表示),它的余弦值近似于指定的浮点表达式。
ASIN(float_expr) 返回角(以弧度表示),它的正弦值近似于指定的浮点表达式。
ATAN(float_expr) 返回角(以弧度表示),它的正切值近似于指定的浮点表达式。
ATN2(float_expr1, float_expr2) 返回角(以弧度表示),它的正切值在两个近似的浮点表达式之间。
CEILING(num_expr) 返回大于或等于数值表达式的最小整数。
COS(float_expr) 返回以浮点表达式表示的近似于指定角度(以弧度表示)的余弦三角函数的值。
COT(float_expr) 返回以浮点表达式表示的近似于指定角度(以弧度表示)的余切三角函数的值。
DEGREES(num_expr)返回数值表达式表示的弧度值对应的度值。
EXP(float_expr) 根据指定的近似浮点表达式,返回指数值。
FLOOR(num_expr) 返回小于或等于数值表达式的最大整数
LOG(float_expr) 根据指定的近似浮点表达式,返回自然对数值。
LOG10(float_expr) 根据指定的近似浮点表达式,返回以为底的对数。
PI() 返回常量值.141592653589793
POWER(num_expr,y) 返回幂为y的数值表达式的值。
RADIANS(num_expr) 返回数值表达式表示的度值对应的弧度值。
RAND([seed]) 随机返回的到之间的近似浮点值,可以对seed指定为整数表达式(可选)。
ROUND(num_expr,length) 对数值表达式截取指定的整数长度,返回四舍五入后的值。
SIGN(num_expr) 对正数执行+1操作,对负数和零执行-1操作。
SIN(float_expr) 返回以浮点表达式表示的近似于指定角度(以弧度表示)的正弦三角函数的值。
SQUARE(float_expr) 返回浮点表达式的平均值。
SQRT(float_expr) 返回指定的近似浮点表达式的平方根。
TAN(float_expr) 返回以浮点表达式表示的近似于指定角度(以弧度表示)的正切三角函数的值。


日期的计算与格式化

GETDATE() 当前的系统日期。
select GETDATE() --结果:2019-05-07 18:34:27.343


DATEADD(日期部分,number,date) 返回带有指定数字(number)的日期(date),该数字添加到指定的日期部分(datepart)
select DATEADD(dd, 5, getdate()) --增加5天时间


DATEDIFF(日期部分,date1,date2) 返回两个日期中指定的日期部分之间的差值。
select DATEDIFF(mm, '2010-1-1', '2010-3-1 00:00:00') --结果:2


DATENAME(日期部分,date) 返回日期中日期部分的字符串形式。
select DATENAME(dw,GETDATE()) --结果:星期二
注:DATENAME 和 DATEPART 的区别,返回的值类型不同,一个是VARCHAR一个是INT,另外就是星期会用本地语言来表示

DATEPART(日期部分,date) 返回日期中指定的日期部分的整数形式。
select DATEPART(dw,GETDATE()) --结果(返回今天是一周中的第几天):3


YEAR(date) 返回指定日期的年份数值
select YEAR(GETDATE()) --结果:2019


MONTH(date)返回指定日期的月份数值
DAY(date)返回指定日期的天数值
注:当显示日期列的内容时如果只显示年月日部分,可以使用CONVERT转换函数对日期列进行转换

CONVERT(VARCHAR(10),日期字段名,120) --120 为日期格式YYYY-MM-DD
SELECT CONVERT(VARCHAR(10),盘点日期,120) AS 盘点日期 FROM 原材料盘点日期明细表

SQL中日期的表示方法及有效范围,如下:

日期部分缩写日期部分缩写
yy1753-9999wk1-53
季度qq1-4小时hh0-23
mm1-12分钟mi0-59
一年中的天dy1-366ss0-59
一月中的天dd1-31毫秒ms0-999
一周中的天dw1-7


标签:
Copyright © 2020 万物律动 旗下 AI算法狮 京ICP备20010037号-1
本站内容来源于网络开放内容的收集整理,并且仅供学习交流使用;
如有侵权,请联系删除相关内容;