网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > 数据库 > SQL技巧
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
网络编程:ASP教程,ASP.NET教程,PHP教程,JSP教程,C#教程,数据库,XML教程,Ajax,Java,Perl,Shell,VB教程,Delphi,C/C++教程,软件工程,J2EE/J2ME,移动开发
数据库:数据库教程,数据库技巧,Oracle教程,MySQL教程,Sybase教程,Access教程,DB2教程,数据库安全,数据库文摘
本月文章推荐
.优化数据库的方法及SQL语句优化的.
.生成100万不重复的8位均匀分布的.
.如何获取SQL Server数据库里表的.
.Sql2005如何用dtexec运行ssis(DT.
.如何转移SQL SERVER数据库.
.轻松解决启用数据库复制时出现的.
.未与信任SQL Server连接相关联的.
.讲解SQL Server线程和纤程的管理.
.怎么清除sql server日志.
.SQL 2005日志文件损坏后应当如何.
.SQL Server 2000遇到的两个问题及.
.SQL优化34条.
.Berkeley DB数据库管理系统的技术.
.将XML文件导入SQL Server 2000.
.讲解OLTP与数据仓库两者之间的不.
.DBA必须具备跨平台管理不同RDBMS.
.分页SQLServer存储过程 .
.SQL Server中Insert与Select的组.
.SQL Server Compact Edition 程序.
.MS SQLSERVER 中如何得到表的创建.

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

发表日期:2008-3-13


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

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

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

上一篇:巧用数据库引擎优化Tuning Advistor和dta 人气:1009
下一篇:讲解SQL Server 2005数据库的同义词Bug 人气:998
浏览全部数据库的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐