数据类型和索引和表

上传人:mg****85 文档编号:49491784 上传时间:2018-07-29 格式:PPT 页数:84 大小:667KB
返回 下载 相关 举报
数据类型和索引和表_第1页
第1页 / 共84页
数据类型和索引和表_第2页
第2页 / 共84页
数据类型和索引和表_第3页
第3页 / 共84页
数据类型和索引和表_第4页
第4页 / 共84页
数据类型和索引和表_第5页
第5页 / 共84页
点击查看更多>>
资源描述

《数据类型和索引和表》由会员分享,可在线阅读,更多相关《数据类型和索引和表(84页珍藏版)》请在金锄头文库上搜索。

1、组长:韩立娜 汇报人:于思会 组员:韩立娜 于思会 刘述玲 程雁春 桓国艳 赵晴晴Oracle数据库中常用的基本数据类 型Sqlserver数据库中常用的数据类型数据类型指定列、存储过程参数及局部变 量的数据特性 数据按照数据类型存储在列中 系统数据类型:系统数据类型是 SQL Server 支持的内置数据类型 用户定义的数据类型:用户根据系统数据类 型自己定义的数据类型系统数据类型 (1)字符型描述所需空间char固定长度的字符数据,最大长度为 8,000 个字符。0 到 8000 字节varchar可变长度的数据,最大长度为 8000 个字符输入数据的实 际长度text 可变长度的数据,最

2、大长度为 231- 1 个字符16 字节的指针, 每个初始化列至少 外加 2000 字节系统数据类型 (2)Unicode 类型描述所需空间nchar固定长度的 Unicode 数据,最大长度 为 4000 个字符0 到 4000 字节 ,具体取决于 定义nvarchar可变长度的 Unicode 数据,最大长度 为 4000 个字符存储大小是输 入数据的实际 长度ntext可变长度的 Unicode 数据,最大长度 为 230-1 个字符16 字节的指针 ,每个初始化 列至少外加 2000 字节系统数据类型 (3)日期类型描述所需空间smalldatetime从 1900.1.1到 2079

3、. 6. 6,精确到 1 分钟4 字节datetime从 1753. 1.1 到 9999. 12. 31,精确到 三百分之一秒,即 3.33 毫秒。8 字节。系统数据类型 (4)数字类型描述所需空间int整型数据,从 231 到 231-14 字节smallint整型数据,从 -215 到 215-12 字节tinyint整型数据,从 0 到 2551 字节decimal带定点精度和小数位数的十进制数 字类型。5-17 字节(由 精度决定)numericdecimal的同义词5-17 字节(由精 度决定)bit整型数据,值为 1 或 01 字节系统数据类型 (5)浮点类型描述所需空间floa

4、t浮点精度数字数据,从 1.79E+308 到 1.79E+3088 字节real浮点精度数字数据,从 3.40E+38 到 3.40E+384 字节。系统数据类型 (6)货币类型描述所需空间money从 263 到 263-1,精确到每个 货币单位的万分之一8 字节smallmoney从 231 到 231-1 ,精确到每个 货币单位的万分之一4 字节系统数据类型 (7)二进制类型描述所需空间varbinary可变长度的二进制数据,最大长度 为 8000 字节输入数据的长 度再加 4 字节binary固定长长度的二进进制数据,最大 长长度为为 8,000 字节节0 到 8000 字节 ,具体

5、取决于 定义image可变长度的二进制数据,最大长度 为 231-1 字节16字节的指针 每个初始化列 至少外加 2000 字节系统数据类型 (8)timestamp整个数据库范围内的唯一数字8 字节特殊类型描述所需空间uniqueidentifier产生全局唯一的标识符(GUID )16字节用户定义的数据类型特性使用系统数据类型定义 具有预定义长度 指定其中是否可存储 null 值 指定是否必须赋予默认值 指定是否要应用现有规则管理用户定义的数据类型 (1)sp_addtype typename = type, phystype = system_data_type , nulltype =

6、 null_type管理用户定义的数据类型 (2) 参数: typename = type 用户定义数据类型的名称。数据类型名 称必须遵循标识符规则,并且在每个数据库中必 须是唯一的。type 是sysname,无默认值。 phystype = system_data_type 物理或 SQL Server 提供的数据类型( decimal、int 等),用户定义的数据类型即基于 该类型。system_data_type 是 sysname,无默认 值。 nulltype = null_type 指定必须如何处理 null 值。null_type 是 varchar(8),设置值为 NULL(

7、默认)、 NOT NULL 或 NONULLAccess数据库常用数据类型Access 2000中字段可用的数据类型有以下几种: 文本(Text):文本、文本与数字、不必计算的数字,最 长255个字符。 备注(Memo):较长的文本,最长64,000字符。 数字(Number)型:用于算术运算的数字。可在“字段 大小”中分字节、整型、单精度等子类型 日期及时间(Date/Time):从100到9999的日期及时间值 。可进行日期及时间的计算。8字节 货币(Currency):货币值。使用货币类型可避免计算 时四舍五入。8字节 自动编号(AutoNumber):添加记录时的自动序号递增:添一条记

8、录,字段值增1;随机:添一条记录,字段值为另一随机数。2. 字段的数据类型是/否(Yes/No):取两种值之一,如 Yes/No、 True/False、On/Off。大小为1位。 OLE对象(Object):可链接或嵌入其他使用OLE 协议的 程序所创建的对象,如Word文档、图象、声音等。最 多1G。对象可链接或嵌入到Access表中。但只能在窗 体或报表中使用绑定对象框来显示。 超链接(Hyperlink):超文本,用作超链接地址。超链 接最多包含三部分:显示文本:在字段或控件中显示的文本;地址:到文件(UNC)或页面(URL)的路径;子地址:在文件或页面中的地址。 查阅向导(Looku

9、p Wizard):由查阅向导创建。字段的 值来自另一个表或数据列表中,可在列表框或组合框 中选择一个数据作为其值。 备注型、超链接型和OLE对象型字段不能索引。 若在表中输入数据后更改字段的数据类型,则在保存表时,由于进行大量数据转换,时间较长;若新的“数据类型”属性的设置与段原数据类型冲突 ,可能会丢失某些数据。 Number、Date/Time、Currency和Yes/No类型具有预定 义格式。可设置格式,但OLE对象型除外 5. 选择数据类型时应注意的问题MySQL数据类型数据类型种类 数值列类型 字符串列类型 日期和时间列类型数据类型种类 数值型 分为整型和浮点型 整型: 可以由十

10、进制和十六进制表示 整数由数字序列组成,如:1,100。 由十六进制表示方法:0x且后面加19和 AF 的任意数字或字母,并且0x中的X不 能大写。 浮点型: 浮点数由一个数字加一个小数点再加上一 个数字组成。两个数字序列不能同时为空。字符串: 由单引号或者双引号括起来的字符或者数字。 如:”abc”,abc10 字符串中要用转义字符才能表示的特殊符号日期和时间值是存储如“2005 -1-1” 或者“12:00:00”这样的 数值的值。在MySQL中日期是按”年-月-日”的顺序。NULL值是一种无类型的值,表示“空,什么也没有”。数值列类型MySQL为除了NULL值外的所有通用数据类型 提供了

11、列类型。列类型是一种手段,通过这种手 段可以描述表的列可以包含什么样类型的值。 数值列类型所有数值列类型的类型名及其说明和所占的 字节数见下表:数值列类型包括整型和浮点型说明:TINYINT, SAMLLINT, MEDIUMINT, INT, BIGINT每个数据类型的取值范围不同,故分别可以 表示不同的数值范围。在定义整型列时,可以指定可 选的显示尺寸M(见上表),M是从1到255的值,它表示 显示列中值的字符数。字符串列类型 所有字符串列类型及其说明和所占的字节数见 下表: 说明: 对于可变长的字符串类型,其长度取决于实际存放 在列中的值的长度。此长度在上表中用L来表示。 附加若干额外字

12、节,用来记录字符串长度,也就是 说总长度等于Ln(n1、2、3、4、8)CHAR和VARCHAR类型CHAR类型和VARCHAR类型长度范围都是0255之间 的大小。他们之间的差别在于MySQL处理存储的方式:CHAR把这个大小视为值的准确大小(用空格填补比较短的 值)。VARCHAR类型把它视为最大值并且只使用了存储字符串实 际上需要的字节数(增加了一个额外的字节记录长度)。因 而,较短的值当被插入一个语句为VARCHAR类型的字段时 ,将不会用空格填补(然而,较长的值仍然被截短 )。BLOB和TEXT类型BLOB是二进制大对象,如果想存储二进制数 BLOB将是最佳选择,而TEXT与之相同,

13、只是 BOLOB按照二进制编码排序(区分大小写), TEXT按照字符文本模式排序(不区分大小写) 。ENUM 和SET类型是特殊的串类型,其列值必须从固定的串集中 选择,二者差别为前者必须是只能选择其中的 一个值,而后者可以多选。(不推荐使用)日期和时间列类型所有时间和日期列类型的类型名及其说明和所 占的字节数见下表: 说明: 每个时间和日期列类型都有一个零值,当插入非法数 值时就用零值来添加 表示日期时必须先按:年,月,日的顺序给出 DATE ,TIME ,DATETIME分别是存储日期,时间与日期 和时间的组合,其格式为“YYYY-MM-DD”, “hh:mm:ss”和“YYYY-MM-D

14、D hh:mm:ss”,对于 DATETIME类型,日期和时间部分都需要 TIMESTAMP 时间戳列类型以YYYYMMDDhhmmss的格式来表示 值,其取值范围是19700101000000到2037年的某个时 间,主要用于记录更改或创建某个记录总结:常用数据类型分类备注和说明数据类型说明 二进制数据类型存储非子符和文本的数据BLOB可用来存储图像 文本数据类型字符数据包括任意字母、符 号或数字字符的组合char固定长度的非 Unicode 字符 数据 varchar可变长度非 Unicode 数据 text存储长文本信息 日期和时间日期和时间在单引号内输入time时间 date日期dat

15、etime 日期和时间数值型数据该数据仅包含数字,包括正 数、负数以及浮点数int smallint整数float double浮点数货币数据类型用于财务数据decimal定点数 Bit数据类型表示是/否的数据bit存储布尔数据类型3.3.3 索引的建立和删除 建立索引是加快查询速度的有效手段 建立索引 DBA或表的属主(即建立表的人)根据需要建立 有些DBMS自动建立以下的索引 PRIMARY KEY UNIQUE一、建立索引 语句格式 CREATE UNIQUE INDEX ON (, ); 用指定要建索引的基本表名字 索引可以建立在该表的一列或多列上,各列名之间用逗号 分隔 用指定索引值

16、的排列次序,升序:ASC,降序: DESC。缺省值:ASC UNIQUE表明此索引的每一个索引值只对应唯一的数据记 录例题 例14 为学生-课程数据库中的Student,Course两 个表建立索引。其中Student表按姓名升序建索引, Course表按课程名称降序建唯一索引。CREATE INDEX stu_sname_index ON Student(S_name); CREATE UNIQUE INDEX course_cname_index ON Course(C_name desc); 删除索引 DROP INDEX ;删除索引时,系统会从数据字典中删去有关 该索引的描述。例15 删除Student表的stu_sname

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 建筑/环境 > 建筑资料

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号