数据库应用技术:第06章 数据表的创建与管理_第1页
数据库应用技术:第06章 数据表的创建与管理_第2页
数据库应用技术:第06章 数据表的创建与管理_第3页
数据库应用技术:第06章 数据表的创建与管理_第4页
数据库应用技术:第06章 数据表的创建与管理_第5页
已阅读5页,还剩14页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、第6章 数据表的创建与管理1本章内容6.1 数据表的建立6.2 数据表的修改 26.1 数据表的建立数据类型 SQL Server支持4种基本数据类型:字符和二进制数据类型、日期时间数据类型、逻辑数据类型、数字数据类型,用于各类数据值的存储、检索和解释。 1.系统数据类型(1)精确数值类型精确数值数据类型用于存储有小数点且小数点后位数确定的实数 。格式:decimal(p, s)numeric(p, s)(2)近似数值类型用于表示浮点数值数据的近似数值数据类型。36.1 数据表的建立(3)日期和时间类型日期时间数据类型用于存储日期和时间数据。SQL Server支持两种日期时间数据类型:dat

2、etime和smalldatetime。 (4)字符串类型字符数据类型用于存储汉字、英文字母、数字符号和其他各种符号。char数据类型 varchar数据类型 text数据类型46.1 数据表的建立(5)Unicode字符串类型SQL Server允许使用多国语言,采用Unicode标准字符集。为此SQL Server提供多字节的字符数据类型:nchar(n)、nvarchar(n)和ntext。(6)二进制字符串类型SQL Server二进制数据类型用于存储二进制数或字符串。 SQL Server的3种有效二进制数据类型: binary数据类型 varbinary(n)数据类型 image数

3、据类型 56.1 数据表的建立(7)其他数据类型1)cursor。游标是变量或存储过程参数OUTPUT的一种数据类型,这些参数包含对游标的引用。2)sql_variant:可变数据类型。该类型的变量可用来存放大部分SQL Server数据类型的值,最大长度为8016字节,不支持text、ntext、timestamp和sql_variant类型。3)table:表类型。这是一种特殊的数据类型,存储供以后处理的结果集。4)Timestamp:时间戳数据类型,用于自动记录插入或删除操作的时间。注意:服务器不允许用户指定时间戳值。5)uniqueidentifier:GUID类型(Global Un

4、ique IDentifier, 全局惟一标识符)。 2. 用户定义数据类型66.1 数据表的建立 使用图形工具创建数据表使用Transact-SQL语句创建表语法格式:CREATE TABLE database_name . schema_name . | schema_name . table_name ( ,.n )76.1 数据表的建立【例6.1续】利用Transact-SQL创建教学数据库中的三张表。CREATE TABLE student( SNO CHAR(4) PRIMARY KEY,SNAME NCHAR(10) NOT NULL,SEX CHAR(1),AGE SMALLI

5、NT,CHECK (SEX=F OR SEX=M),CHECK (AGE BETWEEN 18 AND 25)CREATE TABLE course( CNO CHAR(4),CNAME CHAR(10) NOT NULL,CREDIT SMALLINT,PRIMARY KEY (CNO),CHECK (CREDIT 1 AND 10)86.1 数据表的建立CREATE TABLE s_c( SNO CHAR(4),CNO CHAR(4),GRADE SMALLINT,PRIMARY KEY (SNO,CNO),FOREIGN KEY SNO REFERENCES student(SNO),F

6、OREIGN KEY CNO REFERENCES course(CNO),CHECK (GRADE 0 AND 100)96.2 数据表的修改查看数据表【例6.2】查看系统当前所有对象的信息。单击工具栏上【新建查询】按钮,输入以下代码:USE masterGOEXEC sp_helpGO【例6.3】查看教学数据库中学生表的信息。USE teachingGOEXEC sp_help studentGO106.2 数据表的修改使用图形工具修改数据表使用Transact-SQL语句修改表语法格式:ALTER TABLE database_name . schema_name . | schema_

7、name . table_name ALTER COLUMN column_name type_schema_name. type_name ( precision , scale | max ) NULL | NOT NULL | WITH CHECK | NOCHECK | ADD | ,.n | DROP CONSTRAINT constraint_name | COLUMN column_name ,.n ; 116.2 数据表的修改【例6.4】为教学数据库中的表student添加一个允许空值的列PLACE,而且没有通过DEFAULT定义提供的值。在该新列中,每一行都将有NULL值。U

8、SE teachingGOALTER TABLE student ADD PLACE VARCHAR(20) NULLGOEXEC sp_help studentGO126.2 数据表的修改【例6.5】修改表student以删除列PLACE。USE teachingGOALTER TABLE student DROP COLUMN PLACEGOEXEC sp_help student GO136.2 数据表的修改【例6.6】将表student中列PLACE的数据类型由VARCHAR(20)更改为VARCHAR(10)。USE teachingGOALTER TABLE student ALT

9、ER COLUMN PLACE VARCHAR(10)GOEXEC sp_help studentGO146.2 数据表的修改【例6.7】为表student添加一个包含UNIQUE约束的新列SCARDID。USE teachingGOALTER TABLE student ADD SCARDID CHAR(18) NULLCONSTRAINT my_constraint UNIQUEGOEXEC sp_help studentGO156.2 数据表的修改【例6.8】从表student中删除UNIQUE约束。USE teachingGO ALTER TABLE student DROP CONS

10、TRAINT my_constraint GO EXEC sp_help studentGO166.2 数据表的修改使用图形工具删除数据表使用Transact-SQL语句删除表语法格式如下:DROP TABLE database_name . schema_name . | schema_name . table_name ,.n ; 其中,table_name是要删除的表名。注意:(1) 定义有外键约束的表必须先删除外键约束,才能删除。(2) 系统表不能使用DROP TABLE语句删除。176.2 数据表的修改【例6.9】从当前数据库中删除test1表及其数据和索引。DROP TABLE test1【例6.10】删除teaching数据库中的test2表。DROP TABLE teaching.dbo.test218本章小结(1)表的相关概念:表是数据库中数据的实际存储处所,每个表代表一个实体。表由行和列组成,每行标识实体的一个个体,每列代表实体的一个属性。(2)数据类型:数据类型描述并约束了列中所能包含的数据的种类、所存储值的长度或大小、数字精度和小数位数(对数值数据类型)。(3)空值:未对列指定值时,该列将出现空值。空值不同于空字符串或数值零,通常表示未知。空值会对查询命令或统计函数产生影响,应尽量少使用空值。(4)约束:约束是

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论