<%@ page contentType="text/html; charset=gb2312"%> 数据库快照,自定义函数与计算列的概念
网站公告:   ◆北天JAVA技术网热情为java爱好者服务,本网内容包括JAVA(JSP、servlet、EJB、webservice、j2ee、javabean、应用服务器、JavaScript),数据库(MYSQL、SQL Server、Sybase、Oracle、DB2、数据库综合知识),设计研究(设计模式、Struts、Spring、Hibernate、设计框架、设计综合知识),WEB2.0新技术(主要介绍AJAX),以及各种技术的入门、实例、例子等等,欢迎各位多来坐坐!◆  诚邀各位JAVA爱好者加盟!◆  本网站内容丰富,更新快,保证每周20篇以上!  
加入收藏
设为首页
联系站长
承接项目
  相关资源:网站首页 | 免费培训学院 | 技术论坛 | JAVA聊天室 | 作家专栏 | 开发工具 | 认证考试 | 会员俱乐部
  JAVA技术初学者园地 | jsp与servlet | javascript | Java源代码 | EJB | web service | 应用服务器 | JAVA综合知识
  设计研究设计模式 | 设计框架 | Struts | Spring | Hibernate | 开源项目 | 面向对象设计 | 设计综合知识
  数 据 库MYSQL | SQL Server | Sybase | Oracle | DB2 | Informix | Access | 数据库综合知识
  其他资源:AJAX新技术 | 网站开发 | ERP软件 | OA办公软件 | 商业智能BI | 开发综合知识 | 承接项目 | 项目试用

 
 
数据库快照,自定义函数与计算列的概念
     发布者: 发布时间:2008-03-15

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

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

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



(转载文章请保留出处:北天JAVA技术网(www.java114.com))
 
更多精彩文章:
Firefox 3 内存使用
Firefox 3 内存使用
click Web Framework 1.4发布
click Web Framework 1.4发布
最小的Linux计算机:Picotux
最小的Linux计算机:Picotux
 
最近评论:
        
鍥炲
        
标 题:   
内 容:   
 
                                  
 
免责声明:该文章由网友发表,如果对您造成侵权,请联系站长

首页 - 承接项目 - 网站地图 - 联系我们 -
版权所有北天JAVA技术工作室 ICP证号:粤ICP备06079815号