数据库快照,自定义函数与计算列

简介:
数据库快照,自定义函数与计算列
1.数据库快照
数据库快照就是保存某个数据库在快照那一瞬间的状态.快照和备份原理上有所不同,但是功能有一点相同那就是可以将数据还原为备份的那个时刻.快照的原理是新建一个数据库指针,在原数据库没有变化的情况下快照是不占用空间的,而数据库发生了变化,那么在变化前,被修改的数据页会先复制一份到快照文件中,然后再对原数据页进行修改.显然这样做的好处就是比备份数据库占用空间小.快照是只读的,你可以直接在SQL语句中把他当数据库用:
use snap1;--使用快照
select * from table1
当然也可以实现数据还原功能,在导入数据的时候把数据源选成快照就可以了.
快照的建立似乎不可以在ManagementStudio通过点鼠标完成,只有通过SQL语句来做:
create database snap2
on
( name= DB1,
filename= 'c:\abc.mdf')
as snapshot of DB1
这儿snap2当然就是快照名,而name=DB1这儿的DB1是指要被快照的数据库的数据文件逻辑名称.
一个数据库的逻辑名称可以通过右键某数据库->属性,"文件"选项卡中可以看到.
filename='...'这是指快照文件放在哪个位置.最后那个DB1就是指要被快照的数据库了.
注意:数据库被快照以后是无法删除的.要删除数据库必须先把该数据库的所有快照删除.
2.自定义函数
在数据库->可编程性->函数->标量值函数中可以定义用户自己的函数.
右键"新建标量值函数"后会调用新建函数的模版,按Ctrl+Shift+M可以为模版中各参数赋值.然后在Begin End中间写入自己的SQL语句.
比如我们有一个通过生日计算年龄的函数GetAge();那么写出来的代码如下:
CREATE FUNCTION [dbo].[GetAge]
(
@birthday datetime
)
RETURNS int
AS
BEGIN
DECLARE @Result int
DECLARE @Now datetime
set @Now=getdate();
SELECT @Result= DATEDIFF(yy,@birthday,@Now)
RETURN @Result
END
编写完代码后直接按F5运行就可以将编写的函数保存到数据库中.调用自定义函数也很简单,和一般的函数用法一样不过就是前面必须跟架构名,也就是说要写成dbo.GetAge,而不能直接写GetAge.让我们新建一个查询来测试一下:
select dbo.GetAge('1984/10/10')
返回22,哈哈,函数编写成功.
3.计算列
在数据库表设计的时候有一个比较特殊的列不填写任何设计类型,用户不可以改变该列的值,这就是计算列.
计算列的值是通过一定的函数公式等以另一个或多个列的值为输入值,计算出结果.
打开表或在新建表的时候,在列属性下面就有"计算所得的列规范"项,在"公式"中填入需要的公式便完成计算列的设计.
比如我们有一个表,表中有字段Birthday(datetime类型),那么我们再新建一个列为Age,在公式中填入(isnull([dbo].[GetAge]([Birthday]),(0)))然后保存便可以了.这个时候打开表中数据就可以看到Age字段已经全部显示出来了.
在计算列中不能直接写比较复杂的逻辑,一般要结合自定义函数和计算列,这样就可以完成各种复杂逻辑了.
目录
相关文章
|
3月前
|
存储 缓存 关系型数据库
阿里云数据库 SelectDB 多计算集群核心设计要点揭秘与场景应用
在云原生存算分离架构下,多计算集群的实现从技术方案上看似乎并不存在过多难题。但从产品的角度而言,具备成熟易用的多计算集群能力且能运用于用户实际业务场景中,还有较多核心要点需要深度设计
阿里云数据库 SelectDB 多计算集群核心设计要点揭秘与场景应用
|
5月前
|
数据采集 Java BI
笛卡尔积计算在关系数据库中的高效应用
笛卡尔积计算在关系数据库中的高效应用
|
5月前
|
存储 关系型数据库 分布式数据库
PolarDB,阿里云的云原生分布式数据库,以其存储计算分离架构为核心,解决传统数据库的扩展性问题
【7月更文挑战第3天】PolarDB,阿里云的云原生分布式数据库,以其存储计算分离架构为核心,解决传统数据库的扩展性问题。此架构让存储层专注数据可靠性,计算层专注处理SQL,提升性能并降低运维复杂度。通过RDMA加速通信,多副本确保高可用性。资源可独立扩展,便于成本控制。动态添加计算节点以应对流量高峰,展示了其灵活性。PolarDB的开源促进了数据库技术的持续创新和发展。
313 2
|
7月前
|
SQL 存储 算法
数据库编程大赛:一条SQL计算扑克牌24点
参加NineData举办的数据库编程大赛,展示你的技术才华!用一条SQL语句解决扑克牌24点的计算表达式。这场比赛面向数据库爱好者、开发者、程序员、DBA等,展示你的编程技能,并有机会赢得丰厚奖励。欢迎大家来挑战!
265 0
数据库编程大赛:一条SQL计算扑克牌24点
|
数据库
计算数据库某个表大小
计算数据库某个表大小
|
消息中间件 Kafka 数据库
这个错误通常表示Flink CDC在执行快照时,无法从数据库历史主题中获取到正确的数据
这个错误通常表示Flink CDC在执行快照时,无法从数据库历史主题中获取到正确的数据
49 1
|
7月前
|
关系型数据库 Java 数据库
PostgreSql | 数据库 |自定义函数的设计和实现
PostgreSql | 数据库 |自定义函数的设计和实现
98 0
|
缓存 弹性计算 分布式计算
阿里云适合建网、web应用、数据分析和计算、数据库系统的云服务器价格参考
阿里云服务器新客专享,新用户完成账号实名认证,享受优惠价格购买计算型、通用型、内存型云服务器爆款配置特价优惠,限1-2台,这些云服务器主要适合搭建网站、web应用、数据分析和计算、数据库系统等中小类型和规模的企业级应用。
418 1
阿里云适合建网、web应用、数据分析和计算、数据库系统的云服务器价格参考
|
存储 Cloud Native 关系型数据库
阿里云最新产品手册——阿里云核心产品——云原生关系型数据库PolarDB——计算与存储分离
阿里云最新产品手册——阿里云核心产品——云原生关系型数据库PolarDB——计算与存储分离自制脑图
253 1
|
存储 机器学习/深度学习 NoSQL
「图型计算架构」GraphTech生态系统2019-第1部分:图型数据库
「图型计算架构」GraphTech生态系统2019-第1部分:图型数据库
下一篇
DataWorks