选择显示字体大小

数据库 缺省值


缺省值(default)是往用户输入记录时没有指定具体数据的列中自动插入的数据。缺省值对象与alter table 或create table 命令操作表时用default 选项指定的缺省值功能相似,但缺省值对象可以用于多个列或用户自定义数据类型,它的管理与应用同规则有许多相似之处。表的一列或一个用户自定义数据类型也只能与一个缺省值相绑定。

9.3.1 创建缺省值
(1) 用create default 命令创建缺省值
create default 命令用于在当前数据库中创建缺省值对象,其语法如下:
create default default_name as constant_expression
其中constant_expression 子句是缺省值的定义。constant_expression 子句可以是数学表达式或函数,也可以包含表的列名或其它数据库对象。

例9-11: 创建生日缺省值birthday_defa。
create default birthday_defa
as '1978-1-1'
例9-12: 创建姓名缺省值name_defa。
create default name_defa
as user

(2) 用enterprise manager 创建缺省值
在enterprise manager 中选择数据库对象“defaults”, 单击右键,从快捷菜单中选择n“ew default” 选项,即会弹出如图9-6所示的创建缺省值属性对话框。输入缺省值名称和值表达式之后,单击“确定”按钮,即完成缺省值的创建。

9.3.2 查看缺省值
(1) 用enterprise manager 查看缺省值
在enterprise manager 中选择“defaults”对象,即可从右边的任务板中看到缺省值的大部分信息。如图9-7 所示。也可以选择要查看的缺省值,单击右键,从快捷菜单中选择“properties” 选项,即会出现如图9-8 所示的缺省值属性对话框,可以从中编辑缺省值的
值表达式。修改缺省值名称的方法与修改规则名称的方法相同,可以用sp_rename 存储过程修改,也可以在企业管理器的任务板窗口中直接修改。


(2) 用存储过程sp_helptext 查看缺省值
使用sp_helptext 存储过程可以查看缺省值的细节。
例9-13: 查看缺省值today。
exec sp_helptext today

运行结果如下:
------------------------------------------------------------------
text
------------------------------------------------------------------
create default [dp_date] as getdate()

9.3.3 缺省值的绑定与松绑
创建缺省值后,缺省值仅仅只是一个存在于数据库中的对象,并未发生作用。同规则一样,需要将缺省值与数据库表或用户自定义对象绑定。
(1) 用enterprise manager 管理缺省值的绑定
在enterprise manager 中,选择要进行绑定设置的缺省值,单击右键,从快捷菜单中选择“properties” 选项,即会出现如图9-8 所示的缺省值属性对话框。

图9-8 中的“bind udts…” 按钮用于绑定用户自定义数据类型,“bind columns…”按钮用于绑定表的列。在图9-8 中单击“bind udts…” 按钮,则出现如图9-9 所示的绑定缺省值到用户自定义数据类型的对话框;单击“bind columns…” 按钮,则出现如图9-
10 所示的绑定缺省值到表的列的对话框。用它们来管理缺省值与表的列以及用户自定义数据类型之间的绑定非常方便。

(2) 用存储过程sp_bindefault 绑定缺省值
存储过程sp_bindefault 可以绑定一个缺省值到表的一个列或一个用户自定义数据类型上。其语法如下:
sp_bindefault [@defname =] 'default',
[@objname =] 'object_name'
[, 'futureonly']
其中'futureonly'选项仅在绑定缺省值到用户自定义数据类型上时才可以使用。当指定此选项时,仅以后使用此用户自定义数据类型的列会应用新缺省值,而当前已经使用此数据类型的列则不受影响。
例9-14 :绑定缺省值today 到用户自定义数据类型hire_date 上。
exec sp_bindefault today, hire_date
运行结果如下:
--------------------------- ------------------------------
default bound to data type.
the new default has been bound to columns(s) of the specified user data type.

(3) 用存储过程sp_unbindefault 解除缺省值的绑定
存储过程sp_unbindefault 可以解除缺省值与表的列或用户自定义数据类型的绑定,其语法如下:
sp_unbindefault [@objname =] 'object_name'
[,'futureonly']
其中'futureonly'选项同绑定时一样,仅用于用户自定义数据类型,它指定现有的用此用户自定义数据类型定义的列仍然保持与此缺省值的绑定。如果不指定此项,所有由此用户自定义数据类型定义的列也将随之解除与此缺省值的绑定。

例9-15: 解除缺省值num_default 与表products 的quantity 列的绑定。
exec sp_unbindefault ‘products.[quantity]’
运行结果如下:
--------------------------- ------------------------------
(1 row(s) affected)
default unbound from table column.
注意:如果列同时绑定了一个规则和一个缺省值、那么缺省值应该符合规则的规定。
不能绑定缺省值到一个用create table或alter table命令创建或修改表时用default选项指定了的缺省值的列上。

9.3.4 删除缺省值
可以在enterprise manager 中选择缺省值,单击右键,从快捷菜单中选择“delete” 选项删除缺省值,也可以使用drop default 命令删除当前数据库中的一个或多个缺省
值。其语法如下:
drop default {default_name} [,...n]
注意:在删除一个缺省值前必须先将与其绑定的对象解除绑定。

例9-16: 删除生日缺省值birthday_defa。
drop default birthday_defa

本章小结
数据完整性工具的应用是sql server 的一大特点,它通过在数据库端使用特定的规定来管理流入与输出系统的信息,而不是由应用程序本身来控制信息的类型,这使得数据独立与应用程序成为开放的数据库系统。

  


 


关键字 本文所属关键字

相关 与本文相关文章

分类 所有文章关键字导航

源码编程相关

Java   Asp   PHP   .Net   XML   C/C++   CGI   VB   Jsp   J2ee   J2se   J2me   EJB   Servlet   Tomcat   Resin   Struts   Weblogic   Eclipse   ANT   GUI   JMS   Web servise   IDEA   Webphere   Hibernate   Spring   Jboss   Applet   Swing   Socket   Javamail   Perl   Ajax   P2P   安全   模式   框架   测试   开源   游戏

SQL数据库相关

My-SQL   Ms-SQL   Access   DB2   Oracle   Sybase   SQLserver   索引   存储过程   加密   数据库   分页   视图  

手机无线相关

3G   Wap   CDMA   GRPS   GSM   IVR   彩信   短信   无线   增值业务

网页设计制作相关

HTML   CSS   网页配色   网页特效   Javascript   VBscript   Dreamweaver   Frontpage   JS   Web   网站设计

网站建设推广相关

建站经验   网站优化   网站排名   推广   Alexa

操作系统/服务器相关

Windows XP   Windows 2000   Windows 2003   Windows Me   Windows 9.x   Linux   UNIX   注册表   操作系统   服务器   应用服务器

图形图像多媒体相关

Photoshop   Fireworks   Flash   Coreldraw   Illustrator   Freehand   Photoimpact   多媒体   图形图像

标准 网站致力的规范

Valid CSS!

无不良内容,无不良广告,无恶意代码

Valid XHTML 1.0 Transitional

creativecommons