以前只是了解标量函数这个概念,感觉使用量好像并不大,等我真正做sql编码的时候才发现它的好处。简直太方便了实用了。

我们知道在进行软件开发的时候要定义很多不同类型,每个类型又会分很多项。比如:

搞前端都知道,这就是得下拉框。大多数这样得下拉搜索框都是动态得,也就是说我可以随时增减这里面得项数。而它得value值,一般也都是  value=(int  ) text=开关电源。

牵扯到像这种类型得动态改变下拉框,那么一般数据都要保存得数据库中了,(当然你也可以自己定义一个js文件,改变js文件内容也可以做到),如果存入数据库中,那是怎末存得呢,直接存text值,那么后台取值一般都是去value值。所以,像这样数据库一般都是存value值。但页面显示得时候,用户需要看到得确实text值,而不是一个数字。像这种情况只能两个都存了。而实际我我们只存value只。比如局站类型:

但是,开发一个软件像这种下拉框太多了,都这样存那就比较烦人了,而已不利于后期得管理和维护。那么要怎末做呢。 一般来说,都会建一个字典,专门用来存这些数据得字典。

这样就可以动态改变项数,和改变每一项得参数了。

但是如果这样做的话,我们在从数据库中取数据的时候,取得只是id,但是平台要显示真是类型名字 。比如局站类型:

而这里就要做到我们今天要说的标量函数了。 我们在数据库中新建一个标量函数 Sys_ItemName:

USE [SmartNet]
GO
/****** Object: UserDefinedFunction [dbo].[Sys_ItemName] Script Date: 2019/10/25 星期五 14:45:46 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
ALTER FUNCTION [dbo].[Sys_ItemName]
(
@ItemValue varchar(30),
@PValue varchar(30)
)
RETURNS nvarchar(50)
AS
BEGIN DECLARE @ItemName nvarchar(50);
set @ItemName='' SELECT @ItemName = ItemName FROM Sys_DataItem WHERE ItemValue=@ItemValue and PValue=@PValue RETURN @ItemName END

  而这个函数要取得数据就是我们上面建的通用字典了。

标量函数中,我们定义的两个变量:@ItemValue varchar(30),@PValue varchar(30) 也就是,字典表中对应的ItemValue ,PValue 两列值了。

那接下来就是如何用这个标量函数了:

比如我们根据上面的局站信息表来做演示,查询局站信息表中的所有数据,这里我们只取这一列做演示:

这里我们可以看到局站信息表中,局站类型的id了:和上面的数据库字典对应,(1代表 基站,2代表支局,3代表端局)。但是我做了我们正常搜索,但显示的都是id,页面列表显示总不能都是数字吧,那样只能自己知道是什么了。所以,如果用到标量函数,这个问题就迎刃而解了。

大家可以看到上面的查询结果是真名了。

其实说标量函数,也就是几句话而已,但是我想的是,要用实际场景的实际应用来演示会更容易了解!

Sqlserver 标量函数的更多相关文章

  1. [Irving]SqlServer 标量函数 详解【转】

    --创建用户定义函数.这是一个已保存 Transact-SQL 或公共语言运行时 (CLR) 例程,--该例程可返回一个值.用户定义函数不能用于执行修改数据库状态的操作.--与系统函数一样,用户定义函 ...

  2. SQLServer之创建标量函数

    创建标量函数注意事项 在 SQL Server 和 Azure SQL Database 中创建用户定义函数. 用户定义函数是接受参数.执行操作(例如复杂计算)并将操作结果以值的形式返回的 Trans ...

  3. SQL SERVER中用户定义标量函数(scalar user defined function)的性能问题

    用户定义函数(UDF)分类  SQL SERVER中的用户定义函数(User Defined Functions 简称UDF)分为标量函数(Scalar-Valued Function)和表值函数(T ...

  4. sqlserver自定义函数的创建与调用

    sqlserver中有系统提供的函数,像avg.sum.getdate()等,用户还可以自定义函数. 用户自定义的函数包括:标量函数和表值函数,其中标量函数和系统函数的用法一样,表值函数根据主体的定义 ...

  5. 转载——CLR标量函数、表值函数和聚合函数(UDA)

    本节主要介绍使用CLR创建标量函数,表值函数和聚合函数. 所谓标量函数指的就是此函数只返回一个值.表值函数返回值是一个表.聚合函数是在select语句中使用的,用来聚合一个结果集,类似于Sum()或是 ...

  6. PCB MS SQL 标量函数与表值函数(CLR) 实现文件与目录操作

    一.C#写SQL SERVER(CLR)实现文件操作 标量函数: 文件移动 ,复制,检测文件存在,写入新文件文本,读取文本,创建目录,删除目录,检测目录是否存在 /// <summary> ...

  7. PCB MS SQL 标量函数(CLR) 实现DataTable转HTML的方法

    一.准备需转为HMLT字符串的DataTable数据 在数据库中执行一段SQL返回的数据 需转换后的HTML的文本 <html ><head></head>< ...

  8. PCB MS SQL 标量函数(CLR) 实现DataTable转Json方法

    一.准备需转为json字符串的DataTable数据 在数据库中执行一段SQL返回的数据 需转换后的JSON字符串的效果 [{"TechName":"开料",& ...

  9. PCB 周期计算采用 SQL 函数调用.net Dll 标量函数 实现

    PCB 周期计算采用 SQL函数调用.net Dll实现 (实现代码重用目的) 玩过SQL SERVER数据库经常经需要写存储过程,函数之类的,当业务逻辑过于复杂,用SQL去写简直是恶梦, 这里以PC ...

随机推荐

  1. 响应式布局rem的使用

    在如今移动端,响应式布局的时代,用rem作为单位已经是非常普及的一门小技巧了..rem的单位根据html的font-size来进行换算! 1.rem的兼容性: 如下图所示IE9以上就支持了rem这个属 ...

  2. C++ 语言程序设计(清华大学)1

    1.回文数字判断方法(逆过来数值相等):y=y*10+x%10; x /= 10; return(x==y) 2.int rand(void)函数,所需头文件<cstdlib> ,功能是求 ...

  3. Netty的出现

    原生NIO存在的问题 NIO的类库和API复杂, 使用麻烦: 需要熟练掌握Selector.ServerSocketChannel.SocketChannel.ByteBuffer 等. 需要具备其他 ...

  4. Xmanager 实现图形化安装CentOS7上的软件

    Xmanager 是个很不错的工具,集成Xshell,Xftp,Xstart,Xbrowser等常用的远程工具. 当前需求为:有个软件,哑安装(静默安装)方式,在安装时会遇到配置文件加载不全,安装成功 ...

  5. J - Worker

    Avin meets a rich customer today. He will earn 1 million dollars if he can solve a hard problem. The ...

  6. JuJu团队12月3号工作汇报

    JuJu团队12月3号工作汇报 JuJu   Scrum 团队成员 今日工作 剩余任务 困难 于达 修改batch里给sentence加padding的方法 继续调试 无 婷婷 给crossentro ...

  7. LeetCode1029 两地调度(贪心+java自定义排序回顾)

    题目: 公司计划面试 2N 人.第 i 人飞往 A 市的费用为 costs[i][0],飞往 B 市的费用为 costs[i][1]. 返回将每个人都飞到某座城市的最低费用,要求每个城市都有 N 人抵 ...

  8. Web基础之日志

    Web基础之日志   日志在企业开发中有着不可或缺的作用,它可以用以记录用户操作.系统运行状态和错误信息.日志记录的好坏直接关系到系统出现问题时定位的速度.   最开始的日志一般使用log4j,后来s ...

  9. python爬虫笔记01

    1.urllib库中request,parse的学习 1.1 简单的请求页面获取,并下载到本地 request的使用 from urllib import request # 获取此网页的demout ...

  10. 官网英文版学习——RabbitMQ学习笔记(九)总结

    RabbitMQ与spingboot相整合,主要步骤也很简单: 一.首先需要的是添加依赖 二.需要设置属性,属性主要是设置rabbitmq的地址端口,用户名密码回调等需要用到的一些常量,在整合过程中, ...