SQL函数
文章目录
函数和存储过程的区别
函数和存储过程意义和好处都是一样的。它们的唯一区别就是:存储过程可以没有返回值,也可以有多个返回值,适合做批量插入数据、批量更新等。
函数必须有返回值,而且只能有1个,适合做处理数据后返回1个结果。
存储过程详情可看存储过程
函数类别
函数的语法
内建 SQL 函数的语法是:
创建自定义函数:
创建并执行":计算某学生所选课程总成绩;grade_fun",完成
create function grade_fun
(
@学生 decimail(18,1)
)
returns decimail(18,1)
as
begin
declare @a decimail(18,1)
select @a=sum(grade) from 成绩表 where 学生[email protected]学生
return @a
end
嵌套函数
以下是一个简单的例子:GETDATE()函数的作用是返回当前的日期与时间,但不能返回经过格式化的数据,因为这是CONVERT()函数的功能。要想同时使用这两个函数,可以把GETDATE()函数的输出作为CONVERT()函数的输入参数。
聚合函数
聚合函数应用特定的聚合操作并返回一个标量值(单一值)。返回的数据类型对应于该列或者传递到函数中的值。聚合经常和分组、累积以及透视等表运算一起使用,生成数据分析结果。第7章将详细介绍这个主题,这里仅讨论简单SELECT查询中的一些常用函数。
聚合函数不仅可用在SELECT查询中,还可以和标量输入值一起使用。那么,这样做的意义是什么呢?在下列代码中,将值15传递给下列聚合函数,每个函数的返回值都相同:
它们都返回15。虽然,对同一个值求平均、求和、求最小值、求最大值,所得的结果还是那个值。如果对一个值计数,又会产生什么结果呢?
SELECT COUNT(15)
得到的值是1,因为函数只计数了一个值。
现在做一些有意义的事。聚合函数只有在处理结果集合中的一组数据时才有意义。每个函数都处理某列的非空值。除非使用分组操作(详见第7章),否则不能在同一个SELECT语句中既返回聚合的值,又返回常规的列值。