繁体中文
设为首页
加入收藏
当前位置:技术首页 >> 数据库 >> Sql server >> 数据库快照,自定义函数与计算列的概念

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

2008-04-07 23:14:06  作者:IT动力源  来源:IT动力源收集整理  浏览次数:0  文字大小:【】【】【

    本文主要讲述了数据库快照,自定义函数与计算列的标准概念,详细内容请参考下文:

  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字段已经全部显示出来了.

  注:在计算列中是不能直接写比较复杂的逻辑的,一般需要结合自定义函数和计算列,这样就可以完成各种复杂的逻辑了。


点击收藏到

责任编辑:hefei

本文引用地址: http://tech.itzero.com/2008/0407/35195.html 请粘贴到你的QQ/MSN上推荐给你的好友

相关文章
Windows Server 2008曝设计安全缺陷
Windows Server 2008曝严重漏洞 影响Vista系统安全
设置sql server实现互联网数据库安全复制
在oracle中利用角色增强应用系统安全性
修改SQL Server 2000身份验证模式和系统管理员
sql server 7.0安全问题
sql server 7.0安全模式中最重要的改变
讲解SQL Server 2005数据库的同义词Bug
实例讲解如何从结果集中获得随机结果
详细讲解大型数据库的设计原则与开发技巧
 

最新文章

更多

· 数据库快照,自定义函数与...
· 讲解SQL Server 2005数据...
· 实例讲解如何从结果集中...
· 详细讲解大型数据库的设...
· MS SQL Oracle MySQL查出...
· SQL Server 2000/2005下...
· 详细介绍分级汇总实现的...
· 如何用SQL写出当M*N时的...
· 在SQL Server中获得不包...
· SQL Server 2008关系数据...

热点文章

更多

· SQL2000里的数据类型
· SQL Server导出导入数据方法
· SQL SERVER日志清除的两...
· 实战MSSQL 2000数据库之...
· 向SQLServer数据库读写i...
· SQL转ACCESS解决自动编号...
· SQL Server数据库开发的...
· Asp备份与恢复SQL Server
· SQL Server快速参考
· ASP中调用存储过程、语法...

其它推荐