<script>function StorePage(){d=document;t=d.selection?(d.selection.type!='None'?d.selection.createRange().text:''):(d.getSelection?d.getSelection():'');void(keyit=window.open('http://www.365key.com/storeit.aspx?t='+escape(d.title)+'&u='+escape(d.location.href)+'&c='+escape(t),'keyit','scrollbars=no,width=475,height=575,left=75,top=20,status=no,resizable=yes'));keyit.focus();}</script>数据库快照,自定义函数与计算列
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字段已经全部显示出来了.
在计算列中不能直接写比较复杂的逻辑,一般要结合自定义函数和计算列,这样就可以完成各种复杂逻辑了.
分享到:
相关推荐
7. 自定义函数和存储过程的区别是什么,什么情况下只能用自定义函数,什么情况下只能用存储过程? 这个问题考察的是自定义函数和存储过程的知识。自定义函数可以返回值,存储过程不能返回值;自定义函数可以在 ...
1. **PI数据库快照查询**: 快照查询是指在某一特定时间点获取PI数据库中的数据值。这通常用于获取当前状态或实时数据,如设备的即时温度或压力读数。在源码中,可能会包含与数据库连接、构造查询语句和解析返回...
过程化选件允许用户创建存储过程、函数、过程包和数据库触发器,实现了数据库的自定义逻辑和业务规则,增强了灵活性。开发工具则帮助开发者更高效地构建和管理应用程序,而连接产品则确保了不同系统之间的数据交互。...
4. ADO.NET 2.0集成:SQL Native Client提供了数据库镜像、用户自定义数据类型、XML类型、大数值类型、快照事务隔离等级等功能,提升了应用程序的可用性和性能。 5. 强化的T-SQL:支持SQL-92标准和SQL-1999的新语法...
数据库快照提供了一个数据库在特定时间点的静态视图,无需额外的物理存储空间。不过,它不能用于长期存储,只能用于临时回滚或查看历史数据。 七、自定义脚本备份 对于复杂数据库结构,开发者可能会编写自定义脚...
作为一款成熟的数据库系统,它支持SQL标准,并提供了许多高级特性,如事务处理、多版本并发控制(MVCC)、窗口函数、物质化视图、自定义函数等。本学习笔记将深入探讨这些核心概念,旨在帮助读者全面理解和掌握...
这些函数可以自定义以适应特定的数据库和查询需求。 综上所述,VC-MFC数据库编程涉及了ODBC和DAO两种数据库访问技术,以及MFC中的`CDatabase`、`CRecordset`和`CRecordView`类,通过这些工具,开发者能够方便地构建...
6. **存储过程与函数的区别**:存储过程是用户自定义的、包含一系列SQL语句的集合,可以有输入/输出参数,不一定要返回值。而函数是数据库内置的、预定义的,通常接收参数并返回特定类型的值,通常不涉及特定用户表...
PostgreSQL数据库是一个强大的开源对象关系型数据库系统,其在事务管理方面有着严谨的实现。事务是数据库操作的核心,确保数据的一致性和完整性。本篇文章将深入探讨PostgreSQL中事务的实现方法及其相关概念。 首先...
4. **存储过程和函数**:讲解如何编写存储过程和自定义函数,以实现复杂的业务逻辑和数据处理。 5. **视图**:阐述视图的概念,它是虚拟表,可以提供安全访问和数据抽象,以及简化复杂的查询。 6. **安全性**:...
这部分可能考察了数据库的备份策略(A - 镜像备份),SQL的聚合函数(C - SUM函数),以及数据库的性能监控(A - I/O监控)。 56-60: DCDCD 这部分可能涉及到了数据库的复制技术(D - 主从复制),SQL的子查询(C -...
23210.6 用查询更新表中的数据 23310.6.1 确定你是否能更新查询的特性 23310.6.2 用查询字段属性窗口格式化数据 23410.7 使表的所有字段都可以被访问 23510.8 在多个记录上创建计算 23510.8.1 使用SQL的聚集函数 ...
20、说明:列出数据库里所有的表名 select name from sysobjects where type='U' // U代表用户 21、说明:列出表里的所有的列名 select name from syscolumns where id=object_id('TableName') 22、说明:列示type...
- **应用场景**:用于执行自定义的函数。 #### 28. `EXECUTE PACKAGE`(执行包) - **描述**:允许用户执行包中的函数或过程。 - **应用场景**:用于执行包内的功能模块。 #### 29. `FORCE ANY TRANSACTION`(强制...
用户可以根据需求创建自定义视图,这些视图可能包含特定的列和行,或者对原始表数据进行各种运算后的结果。视图不存储实际数据,而是根据查询时的数据动态生成。以下是视图的一些关键知识点: 1. **创建视图**:...
4. 函数:熟悉内置函数和自定义函数的使用,提升查询效率。 四、安全性与权限管理 1. 用户与角色:创建和管理数据库用户,理解角色的概念,合理分配权限。 2. 权限控制:掌握GRANT、DENY、REVOKE语句,实施精细的...
这一主题深入探讨了如何利用用户自定义函数(User-Defined Function, UDF)来解决这一难题,对于那些在报表开发中遇到类似问题的读者来说,具有极高的实用价值。 ### 核心知识点详解 #### 1. Reporting Services与...
- **模式**与**实例**的关系类似于型与值,模式描述了数据库的结构,实例则是在某一时刻数据库中的实际数据。 6. **数据库系统的组成**: - 硬件平台、操作系统、数据库管理系统、数据库、应用系统和应用开发工具...