运行时存在,而且一直保留。表之间的永久关系是通过索引建立的。
一对多关系:
表之间的一种关系,在这种关系中,主表中的每一个记录与相关表中的多个记录相关联(每一个主关键字值在相关表中可出现多次)。
一对一关系:
表之间的一种关系,在这种关系中,主表中的每一个记录只与相关表中的一个记录相关联。
创建表间的永久关系:
在数据库设计器中,选择想要关联的索引名,然后把它拖到相关表的索引名上,所拖动的父表索引必须是一个主索引或候选索引。建立好关系后,这种关系在数据库设计器中会显示为一条连接两个表的直线。
注意:需先建立索引然后才能建立关系。
删除表间的永久关系:
在数据库设计器中,单击两表间的关系线。关系线变粗,表明已选择了该关系,按下 delete
键。
编辑关系:
单击所需关系线,右击鼠标,从快捷菜单中选择编辑关系,在编辑关系对话框中改选其它相关表索引名或修改参照完整性规则。
参照完整性(RI):
控制数据一致性,尤其是不同表的主关键字和外部关键字之间关系的规则。Visual FoxPro
使用用户自定义的字段级和记录级规则完成参照完成性规则。
第五章 创建查询与视图
5.1 创建查询
1. 查询的概念
查询:就是向一个数据库发出检索信息的请求,从中提取符合特定条件的记录。
查询文件:
即保存实现查询的SELECT-SQL命令的文件。查询文件保存时,系统自动给出扩展名 .qpr; 查询被运行后,系统还会生成一个编译后的查询文件,扩展名为 .qpx。
查询结果:
通过运行查询文件得到的一个基于表和视图的动态的数据集合。 查询结果可以用不同的形式 来保存。查询中的数据是只读的。
查询的数据源:可以是一张或多张相关的自由表、数据库表、视图。
2. 用查询设计器创建查询
基本步骤:
打开查询设计器 → 添加创建查询所基于的数据表 → 定义输出内容 → 设置联接、筛选、 排序、分组条件 → 选择
查询结果的输出形式 → 保存查询文件 →运行查询。
(1)打开查询设计器
方法1:
从文件菜单或工具栏上单击新建 → 查询 → 新建文件 → 进入查询设计器
方法2:
当所用到的数据表已在项目中时,从项目管理器窗口中单击数据 → 查询 → 新建 → 新建 查询 → 进入查询设计器
方法3:从命令窗口中输入命令:
create query 查询文件名 &; 创建新查询
modify query 查询文件名 &; 修改已存在的查询
(2) 定义查询的输出内容
单击字段选项卡 → 从可用字段
列表框中单击所需字段 (当输出的列不是直接来源于表中的 字段时, 单击函数和表达式框边的? 按钮, 打开表达式生成器, 构造出所需的表达式) → 单 击添加按钮 → 所需字段自动出现在选定字段框中。
(3) 设置查询的筛选条件
筛选条件决定将哪些记录显示出来。
在筛选框中构造筛选条件表达式时,要注意在实例框中输入不同数据类型时的格式:
1) 字符串可以不带引号(当与源表中的字段名相同时才用引号);
2) 日期型数值要用{ }括起来;
3) 逻辑型数据两侧要带 .号,如 .T.,.F.
[HAVING 分组中的满足条件 ]
[ORDER BY 排序字段名1 [ASC | DESC] [, 排序字段名2 [ASC | DESC] ...]]
示例:
浏览学生中的查询学生 student.qpr :
SELECT 表xs.xh as , 表xs.xm as , 表xs.xb as 性别, ;
表xs.csrq as 出生日期, 表xs.bj as 班级名称;
FROM 数据test!表xs;
WHERE 表xs.bj =cs1;
ORDER BY 表xs.xh;
INTO TABLE xs
浏览成绩中的按
课程查询 sub_cj.qpr :
SELECT 表xs.bj as 班级名称, COUNT(表xs.xh) as 班级人数, AVG(表cj.cj) as 平均分, ;
MAX(表cj.cj) as 最高分, MIN(表cj.cj) as 最低分;
FROM 数据test!表xs, 数据test!表cj, 数据test!表kc;
WHERE 表cj.xh = 表xs.xh;
AND 表kc.kcm = 表cj.kcm;
AND 表cj.kcm = sc1;
GROUP BY 表xs.bj;
ORDER BY 表xs.bj;
INTO TABLE sub_cj
5.2 创建视图
1. 视图的特点
1) 视图是存在于数据库中的一个虚表,不以独立的