动态网站制作指南
[  QQ表情  ]
[ 投票调查 ]
[ 企业邮箱 ]
[ 网站空间 ]
网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
ASP源码 | .Net源码 | PHP源码 | JSP源码 | JAVA源码 | CGI源码 | VB源码 | C++源码 | Delphi源码 | PB源码 | VF源码 | 汇编 | 服务器
电脑书籍下载:程序设计书籍 | 数据库教程书籍 | 平面与多媒体书籍 | 网络通讯书籍 | 系统管理书籍 | 网络安全书籍 | 认证考试书籍
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!
当前位置 > 网站建设学院 > 网络编程 > 数据库学院 > 数据库技巧
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程
网络编程:ASP教程,ASP.NET教程,PHP教程,JSP教程,C#教程,数据库,XML教程,Ajax,Java,Perl,Shell,VB教程,Delphi,C/C++教程,软件工程,J2EE/J2ME,移动开发
数据库:数据库教程,数据库技巧,Oracle教程,MySQL教程,Access教程,DB2教程,数据库安全,数据库文摘
文章搜索服务
邮件订阅
输入你的邮件地址,
你将不会错过任何关于:
[ 数据库技巧 ]的信息

本月文章推荐
.SQL Server 本机 Web 服务的使用.
.优化SQL Server服务器内存配置的.
.SQL Server如何解决加密问题?.
.SQL Server 2005 创建登录时提示.
.sql语句查询结果合并union all用.
.轻松掌握密码有效性验证失败的处.
.SQL安装问题总结 .
.SQL SERVER中一些常见性能问题的.
.数据库的查、增、删、改.
.SQL Server与Excel数据互导.
.sql server 灾难恢复.
.SQL Server导入excel数据之Bug!.
.SQL Server数据库:虚拟化 VS 多.
.删除无效的SQL SERVER组的几种方.
.sql server转换时间为字符串.
.SQL中Print语句的烦恼 .
.SQL Server安装:"安装文件配置服.
.浅析SQL SERVER一个没有公开的存.
.SQL Server 2008性能和扩展.
.使用SQL Server导入和索引 Micro.

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

文章类别:数据库技巧 | 发表日期: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 人气:317
下一篇:讲解SQL Server 2005数据库的同义词Bug 人气:413
点击此处浏览全部数据库的内容 Dreamweaver插件下载 常用网页广告代码全集
  最新网站源码 最新软件下载
2008-5-16 乘风多用户PHP统计系统 v3.4
2008-5-16 轩溪下载系统 v3.78 build 0515
2008-5-16 普沙B2B 浙江省商贸网 v2.0
2008-5-16 asp抓蜘蛛的小程序 v1.0
2008-5-16 齐齐乐网私服发布站 仿haosf新版
2008-5-16 IssTech信息反馈系统 v1.0
2008-5-16 自由领域大头贴(js接口版) 修正版
2008-5-16 医院网站系统
2008-5-16 智拓-分类信息管理系统 v5.0
2008-5-7 Windows XP SP3 官方英文版
2008-5-7 Windows XP SP3 官方香港中文版
2008-5-7 Windows XP SP3 官方繁体中文版
2008-5-7 Windows XP SP3 官方简体中文版
2008-4-30 Multiple Unzip Wizard 1.02
2008-4-30 Multiple Unrar Wizard 1.0.0
2008-4-30 WinZip Install/Try/Uninstall a
2008-4-30 ZIP压缩文件修复器WzipFix 2.0
2008-4-30 Pentazip 6.01 Build 189 For Wi
  发表评论
姓 名: 验证码: [ 全部贴吧 ] [ 浏览评论 ]
内 容:
[ 汉字翻译拼音 ] [ 广告代码 ] [ 符号对照表 ] [ 进制转换 ] [ 经典小工具 ] [ 个税计算 ] [ 汉字简繁转换 ] [ 普通单位换算 ] [ 公制单位换算 ]
[ 生辰老黄历 ] [ 国内电话区号 ] [ 国家代码与域名缩写 ] [ 文字加密解密 ] [ 健康查询 ] [ 万年历 ] [ 手机号码查询 ] [ ip搜索 ] [ Google PR查询 ]
业务联系 | 广告刊登 | 频道合作 | 投稿荐稿 | 联系方式 | 加入收藏 | RSS订阅
Copyright © 2000-2008 www.knowsky.com All rights reserved | 网络实名:动态网站制作指南 | 沪ICP备05001343号