计算机基础第三四讲_数据库和表(主键与索引)
项目四定义主键、关系和索引
主键、关系和索引在数据库设计中的应用
建立表与表之间的联系
通过关系,可以将不同表中的相关数据进行关联。
实现数据的完整性和准确性
通过关系规则,如外键约束,可以确保数据的准确性和完整性。
主键、关系和索引在数据库设计中的应用
主键、关系和索引在数据库设计中的应用
数据库系统在执行查询时,会利用主 键索引减少需要扫描的数据量。
主键、关系和索引在查询优化中的应用
减少JOIN操作的数据量
通过合理设置关系,可以将多个表的查询结果进行有效的合并,减少不必要的数据量。
提高复杂查询的性能
通过关系,可以将复杂的查询条件进行有效的分解和组合,提高查询性能。
主键、关系和索引在查询优化中的应用
提高数据检索速度
索引的存在使得数据库系统能够快速定位到所需的数据记录。
减少磁盘I/O操作
索引可以减少数据库系统在查询过程中对磁盘的访问次数,提高查询效率。
主键、关系和索引在数据完整性维护中的应用
确保数据的唯一性
通过主键,可以确保表中的每条记录都 是唯一的。
VS
防止数据重复
主键的存在可以防止对同一条记录的重复 插入或更新操作。
或多个字段的组合来唯一标识记录。
主键的作用
唯一标识记录
加速数据检索
主键的主要作用是确保表中的每条记录都 能被唯一地标识,从而在数据检索和操作 时能够准确地定位到特定的记录。
在数据库中,通过主键可以快速地检索和 定位到特定的记录,提高数据检索的效率 。
保证数据完整性
实现表与表之间的关联
主键的存在可以保证数据的完整性和一致 性,防止出现重复记录的情况。
数据库与表
数据库与表
1.1 数据库、表与自由表
1.数据库
执行下面的两条命令,将弹出图5.10所示的窗口:据库文件CJGL.DBC,
扩展名.DBC不能省略
BROWSE
&&浏览表内容
2.表与自由表
表是基本的数据组织单位,对数据管理的核心是对表的管理, 表是按一定结构组织起来的。根据表是否属于数据库,可将表 分为数据库表和自由表。通常将数据库表简称为表。
(2)工作区编号由1到32767,其中前十个工作区中指定的别名是从A到J。 (3)当打开一个表时,系统将该表名默认为该工作区的别名,如USE
XSXI.DBF IN 2(在2号工作区打开XSXI.DBF),SELECT 2与SELECT XSXI功能相同。 (4)在打开一个表时定义其别名,如:
SELECT 3 USE XSXI ALIAS 学生信息表 此时XSXI.DBF的别名为“学生信息表”。 (5)工作区号或别名用来指定工作区。如果指定工作区号为0,则激活尚
(2)记录按“学号”升序排列,索引标识为XH的 普通索引;
(3)记录按“课程号”降序排列,索引标识为 KCH的变通索引
2.使用命令建立索引
格式:INDEX ON <索引关键字> TO <单索引文件名> | TAG <索 引标识>
[OF <复合索引文件名>] [FOR <条件>] [COMPACT] [ASCENDING|DESCENDING] [UNIQUE|CANDIDATE] [ADDITIVE]
分隔。
例14:按学号相等,建立学生信息表XSXI.DBF与成绩信息表 CJXI.DBF的临时关系。
SELECT A
数据库与表第四讲1 (1)
第四讲主键与索引主键:主键是唯一标识表中每一条记录的一个字段或多个字段的组合。
通常每个表都应该有一个主键。
只有定义了主键,表与表之间才能建立起联系,从而能够利用查询、窗体和报表查找和组合不同信息,这也是数据库的主要作用之一。
索引:也是字段属性之一,可对表中的值提高查询和排序的速度及保证记录的正确性唯一性;按索引类型可分为主索引、唯一索引、普通索引三种。
主索引:建立主索引的字段,值必须是唯一的,不能重复,且一有只能有一个主索引唯一索引:建立唯一索引的字段,值必须是唯一的,不能重复,但一个表中可以有多个普通索引:一、主键建立方法:(1)打开表设计器——单击字段选定器——右击\设计选项卡——主键二、索引属性值设置:无:该字段不建立索引有(有重复):给该字段建立索引,并且字段中的值可以重复对应普通索引。
有(无重复):给该字段建立索引,并且字段中的值不能重复.这种字段适合做主索引或唯一索引;主索引:用于起到表中主要的关键字,一个表中只能建立一个,且值唯一;主索引分为两种:单项主索引:给某一个字段创建组合主索引:给多个字段创建注:其实也可以理解为主键就是主索引。
三、表之间的关系Access数据库中表之间相互独立,也相互联系,如学生表中学号和成绩表中学号就存在着联系.如果一对关系中,一端的值是唯一的不能重复,则为主键(父表);而另一端可以重复,则为相关表(子表); 一对多多对多一对一A:建立关系:1、打开数据库——数据库工具——关系2、添加建立关系的表,按主对普通索引的关系连接。
B:参照完整性:参照完整性是在输入或删除记录时,对其中一张表操作(更新、删除),另一张表相应变化,将有助于数据的完整性.C:编辑参照完整性:打开之前建立的关系——选中关系线——右击\工具按钮——编辑关系——在弹出的编辑关系中设置——“实施参照完整性”——确定——保存关系作业:1、给学生表建立学号建立主键(索引);2、给课程表课程代码建立主键(索引);3、给成绩表分别建立三个索引,学号和课程代码为一个组合主索引,给学号和课程代码再分别建立两个普通索引;并对三张表实施参照完整性(级联更新相关字段;级联删除相关字段)。
数据库的几个概念:主键,外键,索引,唯一索引
数据库的几个概念:主键,外键,索引,唯一索引主键:主键是数据表的唯一索引,比如学生表里有学号和姓名,姓名可能有重名的,但学号确是唯一的,你要从学生表中搜索一条纪录如查找一个人,就只能根据学号去查找,这才能找出唯一的一个,这就是主键;如:id int(10) not null primary key auto_increment ;自增长的类型;外键:定义数据表假如某个电脑生产商,它的数据库中保存着整机和配件的产品信息。
用来保存整机产品信息的表叫做 Pc;用来保存配件供货信息的表叫做Parts。
在Pc表中有一个字段,用来描述这款电脑所使用的CPU型号;在Parts 表中相应有一个字段,描述的正是CPU的型号,我们可以把它想成是全部CPU的型号列表。
很显然,这个厂家生产的电脑,其使用的CPU一定是供货信息表(parts)中存在的型号。
这时,两个表中就存在一种约束关系(constraint)——Pc表中的CPU型号受到Parts 表中型号的约束。
首先我们来创建 parts 表:CREATE TABLE parts (... 字段定义 ...,model VARCHAR(20) NOT NULL,... 字段定义 ...);接下来是Pc表:CREATE TABLE pc (... 字段定义 ...,cpumodel VARCHAR(20) NOT NULL,... 字段定义 ...};设置索引若要设置外键,在参照表(referencing table,即Pc表) 和被参照表(referenced table,即parts表) 中,相对应的两个字段必须都设置索引(index)。
对Parts表:ALTER TABLE parts ADD INDEX idx_model (model);这句话的意思是,为 parts 表增加一个索引,索引建立在 model 字段上,给这个索引起个名字叫idx_model。
对Pc表也类似:ALTER TABLE pc ADD INDEX idx_cpumodel (cpumodel);事实上这两个索引可以在创建表的时候就设置。
【数据库】主键,外键,主表,从表,关联表,父表,子表
【数据库】主键,外键,主表,从表,关联表,⽗表,⼦表⼀、前⾔在设计中,hibernate,iBatis等ORM框架的使⽤中经常听说主键,外键,主表,从表,关联表,⽗表,⼦表之类的术语,弄懂它们之前的区别与联系对于和ORM框架的学习使⽤是⾮常有必要的。
⼆、概述下⾯从数据库设计⾓度,ORM框架使⽤(以Hibernate为例),PowerDesigner软件以及实际业务⾓度进⾏⼀下介绍。
(1) 数据库⾓度⽽⾔主键:⼀般情况下,满⾜第⼀范式的表都有⼀个主键Primary key,⽤于唯⼀标⽰数据库中的⼀个字段。
外键:外键是相对于数据库设计中的参考完整性⽽⾔,它与主键之间是彼此依赖的关系。
假设现在有两个表,产品分类表ProductCategory(主键CategoryId)和产品信息表Product(主键ProductId),每类产品都属于⼀个分类。
那么如果产品信息表肯定需要参考产品分类表进⾏定义。
因为如果没有产品分类表,⼜何谈产品分类呢。
所以产品信息表Product需要引⽤ProductCategory中的主键CategoryId 进⾏产品分类定义,Product表中引⽤CategoryId的字段就是外键。
在概念模型(Concept Model)中,从产品分类⾓度看,产品分类和产品之间就是⼀对多的关系,⼀个分类下可以有多个产品。
从产品⾓度看,产品和产品分类之间是多对⼀的关系,多种产品属于⼀个分类。
主表:在数据库中建⽴的表格即Table,其中存在主键(primary key)⽤于与其它表相关联,并且作为在主表中的唯⼀性标识。
(摘⾃百度百科)从表:以主表的主键(primary key)值为外键 (Foreign Key)的表,可以通过外键与主表进⾏关联查询。
从表与主表通过外键进⾏关联查询。
(摘⾃百度百科)关联表:两个数据库及其(数据)表之间的数据的相互依赖和影响关系。
⽐如现有某学校三个数据表:学⽣(学号,姓名),课程(课程名,课程编号),选课(学号,课程号,成绩)。
主键,外键,视图,索引
4.索引(Index):
索引,[1]使用索引可快速访问数据库表中的特定信息。索引是对数据库表中一列或多列的值进行排序的一种结构,例如 employee 表的姓名(name)列。如果要按姓查找特定职员,与必须搜索表中的所有行相比索引会帮助您更快地获得该信息。
1.主键(Primary Key):
数据表里的主键创建一般是唯一的,也就是说在一个表格里最多可以创建一个主键;当然创建逐渐的类型有两种,分为 单一列作为主键和组合主键,其中组合主键就是两个列或多个列组合为主键,这在SQL数据操作中用的不是很多;
主要记住主键的创建规则,唯一且不能为空
2.外键(Foreign Key):
换而言之,如果关系模式R中的某属性集不是R的主键,而是另一个关系R1的主键则该属性集是关系模式R的外键,通常在数据库设计中缩写为FK。
外键 --------> 外键就是指:另外表中是主键 。
3.视图(View):
计算机数据库中的视图是一个虚拟表,其内容由查询定义。同真实的表一样,视图包含一系列带有名称的列和行数据。但是,视图并不在数据库中以存储的数据值集形式存在。行和列数据来自由定义视图的查询所引用的表,并且在引用视图时动态生成。也是机械制图术语,在机械制图中,将物体按正投影法向投影面投射时所得到的投影称为“视图”。
第二章 数据库、表和索引
• 表达式文本编辑框:
用于编辑表达式。从表达式生成器的各列表框中选择出来的选项将显 示在这里,也可以直接在这里输入和编辑表达式。 • 函数列表框: 从中可以选择表达式所需的函数,这些函数按其用途分为字符函数、 数学函数、逻辑函数和日期函数等四个列表框。 • 变量列表框: 从变量列表框中通过双击可以选择表达式所需的变量。在字段列表框 中,列出了当前表和视图的字段变量;在变量列表框中,列出了可用的内 存变量和系统变量。 • 表和视图下拉列表框: 从这个列表框中可以选择当前打开的表和视图。 • 控制按钮: 在表达式生成器中有四个命令按钮:“确定”、“取消”、“检验” 和“选项”。若单击“选项”按钮,进入“表达式生成器选项”对话框, 在该选项对话框中可以设置表达式生成器的参数;单击“检验”按钮可以 检验生成的表达式是否有效。按“确定”按钮完成表达式生成并退出“表 16 达式生成器”。按“取消”按钮放弃对表达式的修改并退出表达式生成器。
3
一、字段名
• 表中的每个字段都是有名称的,比如“学生”表中的“学号”字段,“学 号”即为这个字段的字段名。 • 字段名可以是以字母开头的字母数字串,也可以是汉字。自由表中的字段 名不能超过10个字符,数据库表字段名长度不能超过128个字符。 • 字段名中不接受空格字符。
二、字段类型
• 字段的数据类型应与存储其中的信息类型相匹配。
• 数据库可以存储大量的数据,并提供丰富的数据类型。这些数据可以是一 段文字、一组数据、一个字符串、一幅图像或一段多媒体作品。
• 当把不同类型的数据存入字段时,就必须告诉数据库系统这个字段存储什 么类型的数据,这样数据库系统才能对这个字段采取相应的数据处理方法。
• Visual FoxPro 6.0支持十三种不同类型的数据,每种均有不同的目的和用 途。应为表中的每个字段选取最适合于该字段数据用途的数据类型。
数据库习题
数据库习题第一讲走进数据库1.1 走进数据库1 数据库系统与文件系统的最根本的区别是( ) 。
A.文件系统只能管理程序文件,而数据库系统可以管理各种类型文件B.数据库系统复杂,而文件系统简单C.文件系统管理的数据量少,而数据库系统可以管理庞大数据量D.文件系统不能解决数据冗余和数据的独立性,而数据库系统能正确答案: D2 下述不是 DBA 数据库管理员的职责的是( ) 。
A.完整性约束说明B.定义数据库模式C.数据库管理系统设计D.数据库安全正确答案: C3数据库(DB),数据库系统(DBS)和数据库管理系统(DBMS)之间的关系是()。
A.DBS 包括 DB 和 DBMSB.DBMS 包括 DB 和 DBSC.DB 包括 DBS 和 DBMSD.DBS 就是 DB,也就是 DBMS正确答案: A4 ( )是以一定的组织方式将相关的数据组织在一起,长期存放在计算机内,可为多个用户共享,与应用程序彼此独立,统一管理的数据集合。
正确答案:数据库5 在数据库的三级模式结构中,描述数据库中全体数据的逻辑结构和特征的是( ) 。
正确答案:模式1.2 关系数据库1 在关系运算中,选择运算的含义是( ) 。
A.从一个关系中找出满足给定条件的元组组成一个新的关系B.从一个关系中找出需要的属性组成一个新的关系C.从一个关系中找出满足条件的元组和属性组成一个新的关系D. 以上 3 种说法均是正确的正确答案: A2 在“学生表”中,要查找所有年龄大于 30 岁姓王的男同学,所采用的关系运算是 ( ) 。
A.选择B.投影C.连接D. 自然连接正确答案: A3 在关系运算中, ( )运算得到的新关系中属性个数通常多于原关系中属性个数。
A.选择B.投影C.连接D.并正确答案: C4 在“教师表”中要显示教师的姓名和职称的信息,应采用的关系运算是( )A.选择B.投影C.连接D.差正确答案: B5 传统的集合运算包含并、差、交和( )。
数据库索引和主键
数据库索引和主键1、什么是索引?⾯试时候,常常被问到⾃⼰熟知的Mysql优化技巧,索引⼀定会被提及。
那么,什么是索引呢?索引是⼀种加快海量数据查询的技术。
索引就像是⼩时候的新华字典,有了索引,你可以快速地找到⾃⼰想找的东西。
MySQL索引的建⽴对于MySQL的⾼效运⾏是很重要的,索引可以⼤⼤提⾼MySQL的检索速度。
索引分单列索引和组合索引。
单列索引,即⼀个索引只包含单个列,⼀个表可以有多个单列索引,但这不是组合索引。
组合索引,即⼀个索引包含多个列。
创建索引时,你需要确保该索引是应⽤在 SQL 查询语句的条件(⼀般作为 WHERE ⼦句的条件)。
实际上,索引也是⼀张表,该表保存了主键与索引字段,并指向实体表的记录。
过多的使⽤索引将会造成滥⽤。
因此索引也会有它的缺点:虽然索引⼤⼤提⾼了查询速度,同时却会降低更新表的速度,如对表进⾏INSERT、UPDATE和DELETE。
因为更新表时,MySQL不仅要保存数据,还要保存⼀下索引⽂件。
建⽴索引会占⽤磁盘空间的索引⽂件。
2、索引的优缺点1)优点A.加快数据检索速度和表与表之间的连接;B.可以显著减少查询中分组和排序的时间(使⽤分组和排序⼦句进⾏数据检索时)。
2)缺点A.占物理空间。
B.需要动态维护,降低数据维护速度(update、delete、insert)。
3、索引的分类⼀般索引:这是最基本的索引,它没有任何限制。
值可以重复,可以为空。
唯⼀索引:它与前⾯的普通索引类似,不同的就是:索引列的值必须唯⼀,但允许有空值。
如果是组合索引,则列值的组合必须唯⼀。
聚集索引类似于电话簿,后者按姓⽒排列数据。
由于聚集索引规定数据在表中的物理存储顺序,因此⼀个表只能包含⼀个聚集索引。
但该索引可以包含多个列(组合索引),就像电话簿按姓⽒和名字进⾏组织⼀样。
如果在表中未创建聚集索引,则⽆法保证这些⾏具有任何特定的顺序。
聚集索引..就像我们新华字典中的按拼⾳排序..即你查.."爱"字..可以在前⾯看到"癌"字...但不会看到"受"字..⽽⾮聚集索引..就是新华字典中的按部⾸..笔划排序...聚集索引相当于我们书本上前⾯的⽬录的⼀样,它可以⽅便快速的找到你想找的内容,⽽⾮聚集索引就相当于书最后⼏页的解释,它是对书中某个语句或者是⽣词的解释,就像我们上学时候的地理说⼀样,书后⾯都有各种地理名称的英⽂解释;《数据库原理》⾥⾯的解释:聚集索引的顺序就是数据的物理存储顺序,⽽⾮聚集索引的顺序和数据物理排列⽆关。
数据库设计与管理中的主键索引问题探讨
数据库设计与管理中的主键索引问题探讨一、引言数据库作为现代信息系统的核心组件之一,其设计与管理的重要性不言而喻。
在数据库设计过程中,主键(primary key)和索引(index)是两个非常重要的概念。
主键是数据库表中的一列或一组列,其值可以唯一地标识每一行数据,而索引则是为了加速数据库查询而设计的一种结构。
在实际的数据库设计和管理中,主键和索引之间存在着一些互相影响的问题。
本文旨在探讨这些问题并提出一些解决方案。
二、主键的选择与设计在数据库表中,一个或多个列可以被定义为主键。
主键的作用是用来唯一地标识每一行数据。
在实际使用中,主键通常具有下列特性:1. 不能为空值:主键列的值不能为 NULL。
2. 唯一性:主键列的值必须唯一地标识每一行数据。
3. 不可更改性:主键列的值在插入数据后不能更改。
根据实际应用场景的不同,主键的选择也会有所不同。
主键可以选择单个列,也可以选择多个列。
一般来说,主键应该具有简洁明了、易于管理的特点。
主键的设计应当满足以下的条件:1. 稳定性:主键的值应当是稳定的,不会因为时间、环境等因素而发生变化。
2. 简洁性:主键的值应当足够简洁,方便对数据进行快速访问。
3. 唯一性:主键的值应当保证唯一性,以便于其他表格能够引用它。
4. 没有意义性:主键的值应当是没有意义的,不包含数据的具体信息。
三、索引的作用与设计索引是为了提高数据库查询性能而设置的一种数据结构。
通过索引,可以快速地定位到数据库表中某一行数据所在的位置,从而避免了全表扫描的低效率查询方式。
在数据库设计中,索引是一个非常重要的设计元素,一般会考虑如下几个因素:1. 索引类型:根据实际情况,可以选择不同的索引类型。
如B树索引、哈希索引、全文索引等。
2. 索引列选择:在建立索引时,需要选择一个或者多个索引列。
通常,应该选择被频繁查询的列作为索引列。
3. 索引列顺序:如果建立了多列索引,需要考虑这些列的顺序。
一般来说,应该根据频繁的查询条件来决定这些列的顺序。
VFP数据库 第2章 数据库、表和索引
例:该文本文中,字符字段分隔使用下划线 (_),而字段之间用(*)作为分隔符。 APPEND FROM WYtxt.txt DELIMITED WITH _ WITH CHARACTER *
例:将表XJ2.DBF中所有男同学的记录追加 到表‚学籍表.DBF”的末尾。 SET DEFA TO D:\VFP98 USE 学籍表 APPEND FROM XJ2 FOR 性别=“男‛ LIST USE
(3)向通用型字段中追加
格式:APPEND GENERAL <通用型字段名> FORM < 文件名> […] [DATA 字符串][LINK][CLASS OLE类] 例:USE 基本情况 LOCATE FOR 姓名=“肖文红‛ APPEND GENERAL 照片 FROM 肖文红.BMP BROWSE USE
USE 基本情况 REPLACE 工资 WITH 工资 +100 FOR 职称=“工程师‛ BROWSE FIELDS 编号,姓名,工资 FOR 职称=“工程师‛ USE
7. 删除恢复记录
(1)逻辑删除记录 格式: DELETE [范围][FOR条件][WHILE条件] 功能:为当前表中指定范围内满足条件的记 录加上删除标记。如果缺省所有短语,则只 为当前记录加上删除标记。 说明:DELETE只是逻辑删除。
日期型D:日期型字段用于保存不带时间的日期 值,包含年、月、日三项,取值范围从公元零年1 月1日至公元9999年12月31日。
字段的类型
日期时间型T:与日期型字段不同的是,日期时 间型字段除了包含年、月、日外,还包含了时、 分、秒。日期时间值存储在两个四字节整数的8 个字节中,第一个四字节整数保存日期,剩下的 四字节整数保存时间。时间的最小计时单位为百 分之一秒。如果只填入时间值,而未填写日期值 时,则日期值为null,即空值;如果未指明时间 值,则系统用午夜时间00:00:00AM填入。
主键和二级索引流程
主键和二级索引流程一、主键是啥呀?主键就像是一张表里面超级重要的小队长呢。
它有独特性,就好比在一个班级里,每个同学都有自己独一无二的学号,这个学号就可以当作主键。
它的存在是为了能准确又快速地找到表中的某一条数据。
比如说,在一个记录学生信息的表中,学号作为主键,只要知道学号,就能马上定位到这个学生的所有信息,像姓名呀、成绩呀、家庭住址之类的。
而且呀,主键还能保证数据的完整性,防止出现重复或者混乱的数据。
二、主键的创建流程。
创建主键可有意思啦。
一般在设计数据库表的时候就要考虑好主键啦。
要是用像MySQL这样的数据库管理系统的话,在创建表的时候就可以指定一个字段作为主键。
比如说创建一个“书籍”表,我们可以把“书号”这个字段设为主键。
我们可以用这样的语句(这里只是简单示意哦):CREATE TABLE books (book_id INT PRIMARY KEY, book_name VARCHAR(50), author VARCHAR(30)); 这样就把book_id这个字段变成主键啦。
如果表已经创建好了,也可以修改表结构来添加主键呢。
不过要小心哦,因为这可能会影响到已经存在的数据。
三、二级索引又是啥呢?二级索引就像是主键这个小队长的小助手。
它是基于表中的其他字段创建的一种索引。
为什么要有二级索引呢?因为有时候我们不是根据主键来查找数据的,而是根据其他字段。
比如说在“学生”表中,我们可能经常要根据姓名来查找学生的信息,但是姓名又不是主键。
这个时候,二级索引就派上用场啦。
它可以让我们更快速地根据姓名找到对应的学生记录。
二级索引就像是给那些非主键的字段做了一个特殊的小目录,方便我们快速查找。
四、二级索引的创建流程。
创建二级索引也不难哦。
还是以MySQL为例,如果我们想给“学生”表中的“姓名”字段创建二级索引,我们可以用这样的语句:CREATE INDEX index_name ON students (name); 这里的index_name是我们给这个索引取的名字,students是表名,name就是我们要创建索引的字段啦。
计算机基础第三四讲_数据库和表(主键与索引)
7
创建单字段索引 在设计视图中打开相应的表,单击要创建索 引的字段。在常规选项卡的下方,单击索引属性, 然后单击“有(有重复)”或“有(无重复)”。
8
创建多字段索引
在进行索引查询时,有时按一个字段的值不 能惟一确定一条记录,比如学生信息表,按“姓 名”检索时可能有几个人姓名相同,这样就需要 建立多字段索引。 选择要建立索引的表,打开设计视图,然后 单击常用工具栏上的 按钮,打开索引对话框, 在对话框中进行索引的设置。
⑪.在数据库窗口中,打开所需要的表。 ⑫.单击数据表中的任意单元格。 ⑬.执行“格式”菜单中“行高”命令,打开“行高” 对话框。
31
2.3.4
调整表的外观
⑭. 在“行高”对话框的文本框内输入所需要的行 高,单击“确定”按钮,完成表的行高设置。
32
2.3.4
调整表的外观
Ⅱ.使用鼠标调整字段显示高度:
9
2.2.5
主键和索引
创建索引以后,可以随时打开索引对话框进
行修改和删除索引字段。
10
2.2.6
建立表之间的关系
在表和表之间建立联系,可以保证表间数据在编辑时 保持同步,既对一个数据表进行操作要影响到另外一个表 中的记录。 1
Access表间关系的概念 Access中对表间关系的处理是通过两个表 中的公共字段在表之间建立关系,这两个字段 可以是同名的字段,也可以是不同名的字段, 但必须具有相同的数据类型。此外,也可以在 查询和查询之间建立关系,还可以在表和查询 之间建立关系。
37
2.3.4
4
调整表的外观
冻结列 在实际操作中,有时需要建立比较大的数据表,字段 过多,在数据表视图窗口中,无法看到所有字段,可 以通过冻结列解决这个问题。某些字段被冻结以后, 无论怎样拖动水平滚动条,这些字段始终可见,并显 示在窗口的最左边。 ⑪.在数据库窗口的表对象中,打开表。 ⑫.选定要冻结的字段,执行“格式”菜单中的“冻 结列”命令。 这时被冻结的字段将始终显示在窗口的最左边; 如果不需要冻结列时,可以执行“格式”菜单中的 “取消对所有列的冻结”命令取消冻结操作。
数据库主键及索引
数据库主键及索引⼀、什么是索引?索引⽤来快速地寻找那些具有特定值的记录,所有MySQL索引都以B-树的形式保存。
如果没有索引,执⾏查询时MySQL必须从第⼀个记录开始扫描整个表的所有记录,直⾄找到符合要求的记录。
表⾥⾯的记录数量越多,这个操作的代价就越⾼。
如果作为搜索条件的列上已经创建了索引,MySQL⽆需扫描任何记录即可迅速得到⽬标记录所在的位置。
如果表有1000个记录,通过索引查找记录⾄少要⽐顺序扫描记录快100倍。
⼆、索引的类型MySQL提供多种索引类型供选择:普通索引这是最基本的索引类型,⽽且它没有唯⼀性之类的限制。
普通索引可以通过以下⼏种⽅式创建:创建索引,例如CREATE INDEX <索引的名字> ON tablename (列的列表);修改表,例如ALTER TABLE tablename ADD INDEX [索引的名字] (列的列表);创建表的时候指定索引,例如CREATE TABLE tablename ( [...], INDEX [索引的名字] (列的列表) );唯⼀性索引这种索引和前⾯的“普通索引”基本相同,但有⼀个区别:索引列的所有值都只能出现⼀次,即必须唯⼀。
唯⼀性索引可以⽤以下⼏种⽅式创建:创建索引,例如CREATE UNIQUE INDEX <索引的名字> ON tablename (列的列表);修改表,例如ALTER TABLE tablename ADD UNIQUE [索引的名字] (列的列表);创建表的时候指定索引,例如CREATE TABLE tablename ( [...], UNIQUE [索引的名字] (列的列表) );主键主键是⼀种唯⼀性索引,但它必须指定为“PRIMARY KEY”。
如果你曾经⽤过AUTO_INCREMENT类型的列,你可能已经熟悉主键之类的概念了。
主键⼀般在创建表的时候指定,例如“CREATE TABLE tablename ( [...], PRIMARY KEY (列的列表) ); ”。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
13
14
⑥ 在“关系”窗口中,按住鼠标左键不放,从某
个表中将所要的相关字段拖到其他表中的相关字段
上。相关字段不需要有相同的名称,但它们必须有
相同的数据类型且包含相同种类的内容。若要同时 拖动多个字段,则在拖动之前按下Ctrl键再单击所
需字段。 如图所示。
⑦ 松开鼠标左键后,会出现 “编辑关系”对话框,
⑪.在数据库窗口中,打开所需要的表。 ⑫.将鼠标指针放在表中任意两行选定器之间,鼠 标指针变为上下双箭头形式。 ⑬.按住鼠标左键不放,拖动鼠标上下移动,当调 整到所需高度时,松开鼠标左键即可。
33
2.3.4
调整表的外观
调整字段显示宽度
Ⅰ.使用菜单命令调整字段显示宽度的方法如下:
⑪. 在数据库窗口的表对象中,双击所需要的表。 ⑫. 选择要改变宽度的字段列。 ⑬. 执行“格式”菜单中的“列宽”命令,打开“列 宽”对话框。 ⑭. 在“列宽”对话框的文本框内输入所需要的列宽, 单击“确定”按钮,完成表的列宽设置。
20
2.3.1
2
打开和关闭表
关闭表
⑪. 单击视图窗口右上角的“关闭”按钮。 ⑫. 执行文件菜单中的“关闭”命令。 在关闭表时,如果对表的结构或记录进行过修 改并没有保存,Access会弹出一个保存提示对话框。
21
2.3.2
修改表的结构
用户常需要根据应用的变化对表结构进行修 改,修改的内容主要有添加字段、删除字段、移 动字段的位置等,表结构的修改主要在表的设计 视图完成。表设计视图的工具栏如图所示。
27
2.3.3
3
编辑表的内容
添加记录
在数据表视图中,单击工具栏上的“新记录” 按钮 ,输入记录数据。
4
删除记录 在数据表视图中,选中要删除的记录,然后单 击工具栏上的“删除记录”按钮 即可。
28
2.3.3
5
编辑表的内容
修改记录 在数据表视图中,将光标移到需要修改数据的 位置,就可以修改光标位置的数据信息了。
34
2.3.4
调整表的外观
调整字段显示宽度
Ⅱ.使用鼠标调整字段显示宽度的操作方法如 下:
⑪. 在数据库窗口的表对象中,双击所需要的表。 ⑫. 将鼠标指针放在表中任意两列字段名之间, 鼠标指针变为左右双箭头形式。 ⑬. 按住鼠标左键不放,拖动鼠标左右移动,当 调整到所需宽度时,松开鼠标左键即可。
35
存”命令实现保存。
17
2.2.6
3
建立表之间的关系
编辑表间的关系 对于已经创建好的表间的关系可以进行编辑,如删 除关系或修改关系操作。
① 关闭所有打开的表。 ② 执行“工具”菜单中“关系”命令,打开关系 窗口。 ③ 如果要删除两个表之间的关系,用鼠标左键单 击两个表之间的关系连线,然后按Delete键即可。 如果要修改两个表之间的关系,双击需要更改的 关系连线,打开“编辑关系”对话框,可以在对 话框中重新设置,然后单击“创建”按钮。
Байду номын сангаас
15
参照完整性
参照完整性是建立联系的两个表之间的 约束,当更新、删除、插入一个表中的数据 时,通过参照引用相互关联的另一个表中的 数据,来检查对表的数据操作是否正确。
M M
主表
从表
从表中每条记录M字段的值必须是主表 中存在的
16
⑧ 在“编辑关系”对话框的“表/查询”及“相关
表/查询”列表框下,列出了关系的主表或查询名称
•删除主键
在设计视图中打开相应的表,选中设置为主键的行, 然后单击工具栏上的 按钮。
6
2.2.5
2
主键和索引
索引
对于数据库来说,查询和排序是常用的两种 操作,为了能够快速查找到指定的记录,通常需 要建立索引来加快查询和排序的速度。建立索引 就是要指定一个字段或多个字段,按字段的值将 记录按升序或降序排列,然后按这些字段的值来 检索。 索引字段可以是文本型、数字型、货币型、 日期/时间型,主键字段会自动索引,但OLE对象 和备注字段等不能设置索引。
⑪.在数据库窗口中,打开所需要的表。 ⑫.单击数据表中的任意单元格。 ⑬.执行“格式”菜单中“行高”命令,打开“行高” 对话框。
31
2.3.4
调整表的外观
⑭. 在“行高”对话框的文本框内输入所需要的行 高,单击“确定”按钮,完成表的行高设置。
32
2.3.4
调整表的外观
Ⅱ.使用鼠标调整字段显示高度:
22
2.3.2
修改表的结构
与修改表结构相关的表的设计工具栏按钮功能说明如下: 工具按钮 名称 主键 索引 功能 指定当前字段为主关键字段 打开创建索引对话框
插入行 在当前字段前插入一个新的字段行 删除行 删除当前字段行 属性 打开表的属性对话框 生成器 显示选定项目或属性的生成器
23
2.3.2
修改表的结构
9
2.2.5
主键和索引
创建索引以后,可以随时打开索引对话框进
行修改和删除索引字段。
10
2.2.6
建立表之间的关系
在表和表之间建立联系,可以保证表间数据在编辑时 保持同步,既对一个数据表进行操作要影响到另外一个表 中的记录。 1
Access表间关系的概念 Access中对表间关系的处理是通过两个表 中的公共字段在表之间建立关系,这两个字段 可以是同名的字段,也可以是不同名的字段, 但必须具有相同的数据类型。此外,也可以在 查询和查询之间建立关系,还可以在表和查询 之间建立关系。
7
创建单字段索引 在设计视图中打开相应的表,单击要创建索 引的字段。在常规选项卡的下方,单击索引属性, 然后单击“有(有重复)”或“有(无重复)”。
8
创建多字段索引
在进行索引查询时,有时按一个字段的值不 能惟一确定一条记录,比如学生信息表,按“姓 名”检索时可能有几个人姓名相同,这样就需要 建立多字段索引。 选择要建立索引的表,打开设计视图,然后 单击常用工具栏上的 按钮,打开索引对话框, 在对话框中进行索引的设置。
2.3.4
3
调整表的外观
隐藏列和显示列 隐藏列
⑪. 在数据库窗口的表对象中,打开需要的表。 ⑫. 选中要隐藏的字段。 ⑬. 执行“格式”菜单中的“隐藏列”命令。
36
2.3.4
调整表的外观
显示列
⑪. 在数据库窗口的表对象中, 打开表。 ⑫. 执行“格式”菜单中“取消 隐藏列”命令,打开“取消隐藏 列”对话框。 ⑬. 在“列”列表中选中要显示 列的复选框。 ⑭. 单击“关闭”按钮,被隐藏 的列就重新显示在表中。
注:这种方法只能改变“数据表视图”中字段显示的 顺序,而不会影响“设计视图”中字段结构的顺序。
30
2.3.4
2
调整表的外观
调整字段显示宽度和高度
在数据表视图中,有时由于数据过长或字号过大, 导致数据不能正常显示。这时可以通过调整字段显 示宽度和高度来显示字段中全部数据。 调整字段显示高度
Ⅰ.使用菜单命令:
第6讲 数据库和表
1 2 3 4
创建数据库 建立表 维护表 操作表
2
2.2
1 2 3 4 5 6
建立表
Access数据类型 建立表结构 向表中输入数据
字段属性的设置
主键和索引
建立表之间的关系
3
2.2.5
1
主键和索引
主键
主键是用于惟一标识表中每条记录的一个或一
组字段。Access 建议为每个表设置一个主键,这
2.3
1 2 3
18
维护表
打开和关闭表 修改表的结构 编辑表的内容
4
调整表的外观
19
2.3.1
1
打开和关闭表
打开表
⑪. 在“设计视图”中打开表 在数据库窗口中单击某个表,然后单击窗口中的 “设计”按钮,就可以在“设计视图”中打开该表。 在“设计视图”中可以修改表结构信息。 ⑫. 在“数据表视图”中打开表 在数据库窗口中双击要打开的表,就可以在“数据 表视图”中打开该表。在“数据表视图”中可以进 行表记录的输入、修改和删除等操作。 ⑬. 在两种视图之间切换 单击工具栏中“视图”按钮可以在这两个视图之间 进行切换。
11
2.2.6
建立表之间的关系
建立表间关系的字段在主表中必须是主键和 设置为无重复索引,如果这个字段在从表中也是 主键和设置了无重复索引,则Access会在两个表 之间建立一对一的关系;从表如果是无索引或有 重复索引,则在两个表之间建立一对多的关系。
12
2.2.6
2
建立表之间的关系
建立表间的关系 在建立关系前,需要把相关的数据表关闭。 ① 打开要进行操作的数据库,并切换到数据库窗 口。 ② 单击工具栏中的“关系”按钮 。 ③ 如果该数据库还没有定义任何关系,则会出现 “关系”窗口和“显示表”对话框。 ④ 在“显示表”对话框中,如图所示,选择要建 立关系的表,然后单击“添加”按钮。 ⑤ 当所需的表添加到“关系”窗口后,关闭“显 示表”对话框。
6
复制记录 在数据表视图中,选中要复制的数据,单击工 具栏上的“复制”按钮,将光标移到要放置数据的 位置,再单击工具栏上的“粘贴”按钮,即可完成 复制记录操作。
29
2.3.4
调整表的外观
调整表结构和外观是为了使表更清楚和美观。 调整表的外观包括下面几种操作。
1
改变字段次序 在数据表视图中,有时需要移动某些列来满 足查看数据的要求。方法是: ⑪. 在数据库窗口的表对象中,双击打开表。 ⑫. 将鼠标指针定位在要移动的字段名上,鼠标 指针变为一个粗体黑色向下箭头,按住鼠标左键 拖动该字段到其他位置。
1.添加字段 在设计视图中打开相应的表,选中要在其上面插 入行的那一行字段。然而后单击工具栏的“插入行” 按钮则插入一个空白行,在该行输入要添加字段的各 项信息。最后单击“保存”按钮保存所做的操作。 2.删除字段 在设计视图中打开相应的表,选中要删除的字段 行。然后单击工具栏的“删除行”按钮,则删除所选 中的行。完成删除后,单击“保存”按钮保存所做的 删除操作。