首页 软件下载 产品购买 客户服务 软件定做 加盟 留言 用户 技术文档 新闻
2018年8月18日 星期六   您现在位于: 首页 →  技术文档 → SQL语言(SQL教程)
SQL基础:字段属性
2003年10月10日  作者:  宏达管理软件下载定制开发服务在线  浏览选项:    本文已被浏览 5885 次

    上一节介绍了如何建立包含不同类型字段的表。在这一节中,你将学会如何使用字段的三个属性。这些属性允许你控制空值,缺省值和标识值。

允许和禁止空值

    大多数字段可以接受空值(NULL)。当一个字段接受了空值后,如果你不改变它,它将一直保持空值。空值(NULL)和零是不同的,严格的说,空值表示没有任何值。

为了允许一个字段接受空值,你要在字段定义的后面使用表达式NULL。例如,下面的表中两个字段都允许接受空值:

     

      CREATE TABLE empty (empty1 CHAR (40) NULL,empty2 INT NULL(

  

    注意:

    BIT型数据不能是空值。一个这种类型的字段必须取0或者1。

 

    有时你需要禁止一个字段使用空值。例如,假设有一个表存储着信用卡号码和信用卡有效日期,你不会希望有人输入一个信用卡号码但不输入有效日期。为了强制两个字段都输入数据,你可以用下面的方法建立这个表:

     

      CREATE  TABLE creditcards (creditcard_number CHAR(20) NOT NULL,

                                 Creditcard_expire  DATETIME  NOT NULL)

    注意字段定义的后面跟有表达式NOT NULL。通过包含表达式NOT NULL,你可以禁止任何人只在一个字段中插入数据,而不输入另一个字段的数据。

    你将会发现,在你建设自己的网点过程中,这种禁止空值的能力是非常有用的。如果你指定一个字段不能接受空值,那么当你试图输入一个空值时,会有错误警告。这些错误警告可以为程序调试提供有价值的线索。

 

缺省值

    假设有一个存储地址信息的表,这个表的字段包括街道、城市、州、邮政编码和国家。如果你预计地址的大部分是在美国,你可以把这个值作为country字段的缺省值。

    为了在创建一个表时指定缺省值,你可以使用表达式DEFAULT。请看下面这个在创建表时使用缺省值的例子:

      

      CREATE TABLE addresses (street VARCHAR(60)  NULL,

                               city VARCHAR(40) NULL,

                               state VARCHAR(20) NULL

                               zip  VARCHAR(20) NULL,

                               country VARCHAR(30) DEFAULT  USA)

 

    在这个例子中,字段country的缺省值被指定为美国。注意单引号的使用,引号指明这是字符型数据。为了给非字符型的字段指定缺省值,不要把该值扩在引号中:

   

      CREATE TABLE orders(price  MONEY DEFAULT $38.00,

                           quantity INT DEFAULT 50,

                            entrydate DATETIME DEFAULT GETDATE())

 

    在这个CREATE TABLE语句中,每个字段都指定了一个缺省值。注意DATETIME型字段entrydate所指定的缺省值,该缺省值是函数Getdate()的返回值,该函数返回当前的日期和时间。

 

标识字段

    每个表可以有一个也只能有一个标识字段。一个标识字段是唯一标识表中每条记录的特殊字段。例如,数据库pubs中的表jobs包含了一个唯一标识每个工作标识字段:

   

      job_id   job_desc

      …………………………………………………………….

1                       New Hire Job not specified

2                       Chief Executive officer

3                       Bushness Operations Manager

4                       Chief Financial Officier

5                       Publisher

 

    字段job_id为每个工作提供了唯一的一个数字。如果你决定增加一个新工作,新增记录的job_id字段会被自动赋给一个新的唯一值。

    为了建立一个标识字段,你只需在字段定义后面加上表达式IDENTITY即可。你只能把NUMERIC型或INT型字段设为标识字段,这里有一个例子:

 

       CREATE TABLE visitorID (theID NUBERIC(18) IDENTITY,name VARCHAR(40))

  

    这个语句所创建的表包含一个名为theid的标识字段。每当一个新的访问者名字添加到这个表中时,这个字段就被自动赋给一个新值。你可以用这个表为你的站点的每一个用户提供唯一标识。

    技巧:

    建立一个标示字段时,注意使用足够大的数据类型。例如你使用TINYINT型数据,那么你只能向表中添加255个记录。如果你预计一个表可能会变得很大,你应该使用NUMERIC型数据。

 

    标识字段的存在会使你想尝试许多不可能的事情。例如,你也许想利用标识字段来对记录进行基于它们在表中位置的运算。你应该抛弃这种意图。每个记录的标识字段的值是互不相同的,但是,这并不禁止一个标识字段的标识数字之间存在间隔。例如,你永远不要试图利用一个表的标识字段来取出表中的前十个记录。这种操作会导致失败,比如说6号记录和7号记录根本不存在。

 

使用SQL事务管理器创建新表

    你可以使用前面几节所讲的方法创建新表。但是,使用事务管理器创建新表会更容易。这一节介绍如何使用这个程序创建新表。

    从任务栏的SQL Sever程序组中选择SQL Enterprise Manager,启动该程序,你会看到如图10.4所示的窗口。浏览服务管理器窗口中的树形结构,选择名为Database的文件夹。打开文件夹Database后,选择你在第三章中所建立的数据库。

    

注意:

    如果你还没有创建自己的数据库,回到第三章创建它。你决不要向master,tempdb或任何其它系统数据库中添加数据。

 

    在选择了数据库之后,你会看到一个名为Group/users的文件夹和一个名为objects的文件夹。打开文件夹objects,你会看到许多文件夹,其中一个名为Tables。用右键单击文件夹Tables并选择New table,就会出现如图10.5所示的窗口。

    你可以使用Manager  Tables窗口来创建一个新表。Manager Tables窗口有7个列:Key,Column,Name,Datatype,Size,Nulls和Default。Manager Tables窗口中的每一行标明表中一个字段的信息。

     要建立一个新表,你至少要输入一行信息。在名为Column  Name的列下面键入mycolumn。下一步,选择Datatype列,并从下拉列表中选择CHAR。当你在这两个列中输入信息后,窗口将是如图10.6所示的样子。

     你已经建立了一个只有一个字段的简单的表。单击保存按扭保存这个新表。当要求你输入新表的名字时,输入mytable并单击OK。现在这个表已经保存到了你的数据库中。

如果你打开服务管理器窗口中的文件夹Tables,你会看到你所建立的新表被列出。你可以双击该表的图表来编辑它,这时Manager Tables窗口会重新出现,你可以增加新的字段并重新保存。

    用SQL事务管理器可以做的工作,你都可以用SQL语句来实现。但是,事务管理器使得建表过程变得更加简单。

 发布人:admin
 [ → 我要发表文章 ]
上篇文章:SQL基础:创建新表
下篇文章:SQL基础:向表中添加数据
→ 主题所属分类:  SQL语言 → SQL教程 → 『关闭窗口』
 热门文章
 
 SQL基础:创建新表 (104837)
 最详细的SQL 参考资料下载!! (27237)
 如何利用数据库信息开发平台制作信息管理系统 (11393)
 《数据库信息管理开发平台》疑难解答 (10327)
 SQL基础:使用SQL从表中取记录 (9131)
 随心所欲设计自己的信息管理系统 (8628)
 中级SQL:其它常用的SQL表达式,函数,和过程(2) (8523)
 菜鸟也可做软件 (8507)
 数据库开发平台的问题 (8349)
 中级SQL:SQL核心语句 (8059)
 最近更新
 
 OraCle的常见问题和技术指导 (1月10日)
 最新推出《箱包材料批发管理系统》软件,敬请查看... (11月25日)
 最新推出《会展物流辅助管理系统》软件,敬请下载... (11月3日)
 最新推出《宏达劳教人员管理系统》软件,敬请查看... (10月31日)
 最新推出《宏达图书音像进销存管理系统》软件,敬... (10月31日)
 最新升级《宏达计件工资管理系统》软件,敬请查看... (10月22日)
 最新升级《宏达代理人保险管理系统》软件,敬请查... (10月22日)
 最新升级《宏达车辆配件管理系统》软件,敬请查看... (10月22日)
 最新推出《宏达制药行业销售管理系统》软件,敬请... (10月22日)
 最新推出《宏达机动车整车出厂合格证管理系统》软... (10月22日)
 文章搜索
 
搜索选项:            
关于我们 - 站内短信 - 与我在线 - 管理
Copyright © 2003-2008 宏达管理软件下载定制开发服务在线 All Rights Reserved(鲁ICP备05057070号)

鲁公网安备 37150202000143号

 当前有 158 人在线