关系数据库SQL之可编程性函数(用户自定义函数)

前言

在关系型数据库中除了前面几篇基本的数据库和数据表操作之外,还提供了可编程性的函数、存储过程、事务、触发器及游标。

本文介绍的是函数。

函数分为两种:

  1. 系统函数

  2. 用户自定义函数


准备工作

这里以银行存取款为例说明。

1、创建数据表

--创建账户信息表
create table AccountInfo
(--账户IDCustID int identity(1,1) primary key,--帐户名称CustName varchar(20) not null,--身份证号IDCard varchar(18),--电话TelePhone varchar(13) not null,--地址Address varchar(50) default('地址不详')
)go--创建卡信息表
create table CardInfo
(--银行卡卡号CardID varchar(19) primary key,--银行卡密码CardPassWord varchar(6) not null default('888888'),--身份证号CustID int references AccountInfo(CustID),--存款类型SaveType varchar(10) not null ,--开户日期OpenDate datetime not null default(getdate()),--开户金额OpenMoney money not null check(OpenMoney>1),--可用余额LeftMoney money  not null check(LeftMoney>1),--是否挂失IsLost varchar(2) not null default('否')
)go--交易信息表
create table TransInfo
(--交易编号transID int identity primary key,--银行卡卡号CardID varchar(19) not null,--交易类型TransType varchar(4) not null,--交易金额TransMoney money not null,--交易时间TransDate datetime default(getdate())
)
go/*
1.使用T-SQL语句为交易信息表(TransInfo)的银行卡卡号(CardID)字段创建外键
*/--外键(银行卡卡号CardID)
alter table [dbo].TransInfo  with check add  constraint [fk_CardInfo_TransInfo] foreign key(CardID)
references [dbo].[CardInfo] (CardID)
go/*
2.使用T-SQL语句为账户信息表(AccountInfo)的银行卡卡号(IDCard)字段创建唯一约束
*/
alter table [dbo].[AccountInfo] add unique (IDCard ASC)
go/*
3.使用T-SQL语句创建约束,使银行卡信息表(CardInfo)的银行卡卡号(CardID)字段值长度只能为19位
*/
alter table [dbo].[CardInfo] add constraint CK_CardID check(len(CardID) = 19)
go/*
4.使用T-SQL语句使交易信息表(TransInfo)的交易类型(TransType)字段只能选择'存款'和'取款',银行卡信息表(CardInfo)的存款类型(SaveType)字段只能选择'定期'和'活期'
*/
alter table [dbo].TransInfo add constraint CK_TransType 
check(TransType = '存款' or TransType = '取款')
go
alter table [dbo].CardInfo add constraint CK_SaveType 
check(SaveType = '定期' or SaveType = '活期')
go

2、插入基本数据

--插入三个账户信息
insert into AccountInfo values('孙悟空','422322001502110017','027-88888888','花果山'),('唐僧','420322001902140019','027-85368962','大唐'),('沙和尚','410340001572144714','13295654665','通天河')
insert into CardInfo values('1027 3526 1536 1135','888888',1,'定期',default,500,500,'否'),('1029 3326 1536 1235','888888',2,'活期',default,1500,1500,'否'),('1324 3626 7532 1935','888888',1,'活期',default,4500,4500,'否')

函数调用

SELECT 字段列表/* FROM <函数名称>([参数列表]);

系统函数

数据库系统定义的函数,即内置函数。

函数列别说明
聚合函数执行的操作是将多个值合并为一个值。例如 COUNT、SUM、MIN 和MAX。
配置函数是一种标量函数,可返回有关配置设置的信息。
加密函数支持加密、解密、数字签名和数字签名验证。
游标函数返回有关游标状态的信息。
日期和时间函数可以更改日期和时间的值。
数学函数执行三角、几何和其他数字运算。
元数据函数返回数据库和数据库对象的属性信息。
排名函数是一种非确定性函数,可以返回分区中每一行的排名值。
行集函数返回可在 Transact-SQL 语句中表引用所在位置使用的行集。
安全函数返回有关用户和角色的信息。
字符串函数可更改 char、varchar、nchar、nvarchar、binary 和 varbinary 的值。
系统函数对系统级的各种选项和对象进行操作或报告。
系统统计函数返回有关 SQL Server 性能的信息。
文本和图像函数可更改 text 和 image 的值。

具体的函数如果不清楚请自行搜索,本文着重介绍用户自定义函数。


用户自定义函数

除了系统提供的函数,用户可以根据自己的需求自定义函数;
用户自定义函数,顾名思义,就是数用户自己定义的函数;
用户自定义函数分为两类:表值函数和标量值函数;
其中,表值函数也分两种:内联表值函数和多语句表值函数。


表值函数

表值函数是返回一个Table类型,相当与一张存储在内存中的一张虚拟表。

内联表值函数

语法

CREATE FUNCTION <函数名称> 
(    -- 添加函数所需的参数,可以没有参数[<@param1> <参数类型>][,<@param1> <参数类型>]…
)
RETURNS TABLE 
AS
RETURN 
(-- 查询返回的SQL语句SELECT查询语句
)

示例

/*
* 创建内联表值函数,查询交易总额大于1W的开户人个人信息
*/
create function getCustInfo()
returns @CustInfo table  --返回table类型
(--账户IDCustID int,--帐户名称CustName varchar(20) not null,--身份证号IDCard varchar(18),--电话TelePhone varchar(13) not null,--地址Address varchar(50) default('地址不详')
)
as
begin--为table表赋值insert into @CustInfoselect CustID,CustName,IDCard,TelePhone,Address from AccountInfo where CustID in (select CustID from CardInfo where CardID in (select CardID from TransInfo group by CardID,transID,TransType,TransMoney,TransDate having sum(TransMoney)>10000))return
end
go
-- 调用内联表值函数
select * from getCustInfo()
go

多语句表值函数

语法

CREATE FUNCTION <函数名称> 
(    -- 添加函数所需的参数,可以没有参数[<@param1> <参数类型>][,<@param1> <参数类型>]…
)
RETURNS 
<@定义的表名> TABLE 
(-- 添加返回数据表的列<列名1> <数据类型1>, <列名2> <数据类型2>,……<列名n> <数据类型n>]
)
AS
BEGIN--为<@定义的表名>赋值的SQL语句RETURN 
END

示例

/*
* 创建多语句表值函数,可以查询出一个月内有交易记录的用户姓名,联系电话,身份证号码,银行卡卡号和账户余额
*/
create function getCustInfoMonth()
returns @CustInfo table  --返回table类型
(--帐户名称CustName varchar(20) not null,--电话TelePhone varchar(13) not null,--身份证号IDCard varchar(18),--银行卡卡号CardID varchar(19) not null,--可用余额LeftMoney money  not null check(LeftMoney>1)
)
as
begin--为table表赋值insert into @CustInfoselect A.CustName, A.TelePhone, A.IDCard, T.CardID, C.LeftMoneyfrom AccountInfo as A inner join CardInfo as C on A.CustID = C.CustID inner join TransInfo as T on C.CardID = T.CardID where exists(select * from TransInfo group by CardID,TransDate,transID,TransType,TransMoneyhaving datediff(MONTH,TransDate,GETDATE())=0)return
end
go
-- 调用多语句表值函数
select * from getCustInfo()
go

标量值函数

返回一个标量值

语法

CREATE FUNCTION <FunctionName> 
(-- 添加函数所需的参数,可以没有参数[<@param1> <参数类型>][,<@param1> <参数类型>]…
)
RETURNS <函数返回数据类型>
AS
BEGIN-- 定义返回数据变量DECLARE @变量名 数据类型-- 通过SQL语句为返回变量赋值SELECT @变量名 = SQL语句-- 返回结果RETURN @变量名END

示例

/*
7.创建标量值函数,根据用户传入的银行卡卡号,获得该卡交易次数
*/
create function getTransCount
(@CardID varchar(19)  --参数银行卡卡号
)
returns int  --返回int类型
as
begindeclare @count intselect @count = count(*) from TransInfo where CardID = @CardIDreturn @count
end
go
-- 调用标量值函数
select getTransCount('1027 3526 1536 1135') as 次数
go

函数部分介绍到这里,如有疑问,请留言。

谢谢各位看官的浏览。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/261359.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

土压力图怎么画_电气系统图怎么画?

电气系统图&#xff0c;又称为电气系统控制图&#xff0c;是通过使用国家规定的图形符号和文字代号代表各种电器、电机及元件&#xff0c;根据生产机械的要求和各种电器的原理&#xff0c;用线条代表导线连接起来&#xff0c;用于展示供电线路与各设备工作原理及其相互关系的一…

考勤助手——数据库3.0版本

基于数据库1.0及2.0版本&#xff0c;我们将细节的地方逐一进行讨论&#xff0c;设计出了数据库3.0版本。 根据ER图&#xff0c;进行基本表的设计如下&#xff1a; 转载于:https://www.cnblogs.com/GG-TEN/p/5471019.html

幽灵交易策略_幽灵交易者策略(附源代码)

NO1 . 前言正如幽灵交易者的名字&#xff0c;该策略的核心思路是&#xff0c;在真实下单交易之前&#xff0c;先虚拟出一个交易&#xff0c;如果这个虚拟的交易是亏损的&#xff0c;那么下一次才启动真实的交易。NO2 . 策略简介该策略思路源自于交易者的观察&#xff0c;交易者…

test blog

blogsdf sdfsd转载于:https://blog.51cto.com/11570194/1771304

并行编程——内存模型之缓存一致性

1 定义 缓存一致性 Cache coherence 简称 CC&#xff0c; 缓存一致性协议是在共享缓存多处理器架构确保最终一致性最突出、最重要的机制。这些协议在缓存线&#xff08;cache-line&#xff09;级别实现了对一致性的保证。缓存线是从主内存中读取数据和向内存中写入数据的缓存单…

Start Instance 操作详解 - 每天5分钟玩转 OpenStack(31)

本节通过日志文件详细分析 instance start 操作。下面是 start instance 的流程图向 nova-api 发送请求nova-api 发送消息nova-compute 执行操作下面我们详细讨论每一个步骤。 向 nova-api 发送请求客户&#xff08;可以是 OpenStack 最终用户&#xff0c;也可以是其他程序&…

失望时想起了你是什么歌_你是空你是空是什么歌 你是风你是风什么歌

“你是空&#xff0c;你是空”“你是风&#xff0c;你是风”“下起雨想起了你”前奏的歌曲最近在抖音受到很多人的喜欢&#xff0c;想要找到完整版歌词作为BGM&#xff0c;这首歌非常的洗脑&#xff0c;你是空你是空是什么歌&#xff1f;你是风什么歌&#xff1f;下面八宝网带来…

ASP.NET MVC从视图传递多个模型到Controller

从后台组织好数据然后传递到页面倒是水到渠成很方便&#xff0c;因为MVC自身就将这样的需求内建到了这个系统中。我只需要在后台组织好一个List 或IEnumerable类型的变量&#xff0c;将需要传递的数据模型扔进去便可。 比如这里我们向视图返回5条product信息在页面进行展示&…

还原virtual函数的本质-----C++

当你每次看到C类中声明一个virtual函数&#xff0c;特别是看到了一个virtual的虚构函数。你知道它的意思吗&#xff1f;你肯定会毫不犹豫的回答&#xff1a;不就是多态么。。。在运行时确定具体的行为么。。。完全正确&#xff0c;但这里我要讲的不只是这些东西。 有些类需要虚…

0511 backlog 项目管理

SCRUM 这次的作业就是确定SCRUM的计划&#xff0c;确定sprint backlog的一个冲刺周期&#xff0c;而这个周期是两个星期。争取在两周内发布1.0版本。 本次作业以网站构建为主&#xff1a; ID NAMEIMPESTHOW TO DONOTES1首页99小时用户登录网站也可以看游客的推广的内容&am…

4月27日微软云训练营活动-现场图集

1.签到 2.到场同学&#xff0c;这一天是工作日&#xff0c;但是人气依然很火。 转载于:https://www.cnblogs.com/finehappy/p/3262296.html

Java中内存中的Heap、Stack与程序运行的关系

堆和栈的内存管理 栈的内存管理是顺序分配的&#xff0c;而且定长&#xff0c;不存在内存回收问题&#xff1b;而堆 则是随机分配内存&#xff0c;不定长度&#xff0c;存在内存分配和回收的问题&#xff1b;堆内存和栈内存的区别可以用如下的比喻来看出&#xff1a;使用堆内存…

mysql 5.6 linux安装配置_linux手动安装配置mysql5.6

1.准备工作①官网下载&#xff1a;https://dev.mysql.com/downloads/mysql/5.6.html#downloads下载之后上传到服务器。②创建linux组用户groupadd mysqluseradd -g mysql mysql2.安装①解压&#xff0c;比如放到了/usr/local/,进入到该目录下&#xff0c;进行用z解压gz包&#…

KVM安装Windows Server 2008 R2使用virtio硬盘

在上一篇文章中&#xff0c;我们介绍了使用IDE硬盘来安装Windows Server 2008 R2,这篇文章我们来介绍使用virtio硬盘来安装Windows Server 2008 R2。 说明&#xff1a;KVM默认使用的硬盘格式为virtio。 使用virtio接口的硬盘&#xff0c;我们必须加载virtio硬盘驱动。如果不加载…

Sublime Text 2 入门及技巧

看了 Nettuts 对 Sublime Text 2 的介绍&#xff0c;立刻就兴奋了&#xff0c;诚如作者 Jeffrey Way 所说&#xff1a;“《永远的毁灭公爵》都发布了&#xff0c;TextMate 2 还没发”&#xff0c;你还能指望它么&#xff1f;TextMate 开发者的消极态度已经无法让人忍受了。而作…

YII 配置文件

用YIIFramework的库开发 Java代码 .... Yii::createWebApplication($config); //没有run Yii::import&#xff08;class1&#xff0c;true&#xff09;,在将class1类文件路径存储时&#xff0c;同时include该文件 注意&#xff1a;你也可以将配置文件分为多个文件&#xff0…

mysql装完后navicat无法连接_重装mysql后导致Navicat连接失败

今天重装了mysql数据库&#xff0c;然后再使用navicat去连接数据库的时候&#xff0c;一直报错 1251 Client does not support authentication protocol requested by server解决方法&#xff1a;1、cmd登录mysql2、修改Navicat中连接数据库的密码3、刷新mysql的系统权限表flus…

怎样创建XML文档

在程序中&#xff0c;我们怎样创建一个XML文档。下面演示中&#xff0c;Insus.NET在程序创建一个和http://www.cnblogs.com/insus/p/3274220.html 一模一样的XML文档。可以在HTML markup放一个铵钮&#xff1a; 去.aspx.cs写按钮事件&#xff1a; 上图代码示例中&#xff0c;右…

Windows Server 2008设置远程桌面连接的最大数量

远程桌面连接的默认数量是2&#xff0c;当有多个用户需要同时远程桌面连接时很不方便&#xff0c;可以设置远程桌面连接的最大数量。 1. 运行gpedit.msc&#xff1b; 2. 选择计算机配置-->管理模板-->Windows组件-->远程桌面服务-->远程桌面会话主机-->连接&…

错误: 元素值必须为常量表达式_C语言编程常见错误集锦 【下】

1、输入数据时&#xff0c;规定精度输入数据时不能规定精度。2、switch语句中漏写break语句由于漏写了break语句&#xff0c;case只起标识的作用&#xff0c;而不起判断的作用。当grade的值为A时&#xff0c;程序会从上到下执行完&#xff0c;五个printf都输出。正确的写法应为…