数据库的查询和视图
《数据库及应用——VFP》-- 查询与视图
8.2.3 创建远程视图
1.创建远程数据联接
远程视图是通过ODBC从远程数据源建立的视图。
所谓ODBC即Open DataBase Connectivity (开放式数 据互连)的英语缩写,它是一个标准的数据库接口, 以一个动态连接库(DLL)方式提供的。 创建ODBC数据源可以用二种方法建立。第一种方法是 利用 “连接设计器”中“新的数据源”创建,第二 种方法是利用在windows系统的“控制面板”中启动 “ODBC数据源(32位)”应用程序。
8.1.2 查询的创建
1.利用“查询向导”创建查询 利用“查询向导”创建查询的步骤如下: (1)进入“查询向导” 进入“查询向导”可用下面3种方法:
① 选择【工具】|【向导】|【查询】命令。
② 选择【文件】|【新建】命令,进入“新建”对话 框,选择“查询”单选按钮,单击“向导”按钮。
③ 在“项目管理器”窗口中,选择“数据”选项卡, 选中“查询”,单击“新建”按钮,出现“新建查 询”对话框,单击“查询向导”按钮。
使用方式不同:视图只有所属的数据库被打开时,才能 使用。而查询文件可在命令窗口中执行。
8.2.2 本地视图的创建 1.使用本地视图向导创建本地视图
2.使用视图设计器创建本地视图
建立本地视图
1)使用sql语句建立视图。在使用sql语句建立视图 时,要先打开数据库,建入建立视图的sql命令。 在命令窗口建入: open database<数据库名> create view<视图名> as <select-sql 命令> 2)使用“视图设计器”建立视图。 ①打开“视图设计器”。 打开“视图设计器”的方法与打开“查询设计器”的 方法相似。
06第8章:查询和视图
7
打开查询设计器
方法:“文件”→“新建”→“查询”
数据库系统原理及应用
8
四、视图
视图的含义:
视图:是引用一个或多个表或其他视图的字段而构成 的一种虚拟表,它的定义保存在数据库中 某个视图一旦被定义,就具有与普通数据表类似的功 能,可以像数据库表一样接受用户的访问。视图所引 用的表称为基表 视图只能依赖于某一个数据库而存在,只有打开数据 库,才能创建和使用视图
数据库系统原理及应用
4
二、数据查询
格式:
Select [All|Distinct] {*|目标列表达式 [as 别名][,„]} From 表名或视图名[,表名或视图名,„„] [Where 条件表达式] [Group by 字段名1][Having 条件表达式] [Order by 字段名2][Ascending|Descending]
第8章:查询和视图
教学目的: 熟练掌握select查询命令 了解视图和查询文件的区别 熟练掌握视图设计器和查询设计器的使用
1
一、什么是SQL
SQL:结构化查询语言(Structured Query Language) 是一种对关系数据库中的数据进行定义和操作的句法, 为大多数关系数据库管理系统所支持的工业标准 1974年,由Boyce和Chamberlin提出,并在IBM的数据 库管理系统 System R 上实现 1986年,SQL被美国国家标准局(ANSI)批准作为关系 数据库语言的标准,后来又被国际标准化组织(ISO) 采纳,现已成为业界的标准 目前,几乎所有的数据库管理系统DBMS都支持SQL或提 供SQL接口
数据库系统原理及应用
2
一、什么是SQL
SQL语言的特点: 一体化:包含了查询、操纵、定义和控制功能,即包 含了数据语言中的数据定义语言DDL、数据操纵语言 DML和数据控制语言DCL • 数据查询:Select • 数据定义:Create、Alter、Drop • 数据操纵:Insert、Update、Delete • 数据控制:Grant、Revoke 高度非过程化: 只提出“做什么”,不必指明“怎么做”——用户无 需了解存取路径及物理地址——减轻用户负担,提高 效率
数据库实验5 多表查询及视图
实验五:多表查询及视图一、实验目的1.掌握SELECT语句的基本语法和查询条件表示方法;2.掌握数据表的连接查询、嵌套查询、集合查询的使用方法。
3.掌握创建及管理视图的方法;二、实验学时2学时三、实验要求1.了解SELECT语句的基本语法格式和执行方法;2.掌握连接查询、嵌套查询和集合查询的语法规则;3.掌握使用界面方式和命令方式创建及管理视图;4.完成实验报告;四、实验内容1.以实验3数据库为基础,请使用T-SQL 语句实现进行以下操作:1)查询选修了‘数学’或者‘大学英语’的学生学号、姓名、所在院系、选修课程号及成绩;2)查询与‘张力’(假设姓名唯一)年龄不同的所有学生的信息;3)按照“学号,姓名,所在院系,已修学分”的顺序列出学生学分的获得情况。
其中已修学分为考试已经及格的课程学分之和;4)查找选修了至少一门和张力选修课程一样的学生的学号、姓名及课程号;5)查询只被一名学生选修的课程的课程号、课程名;6)使用嵌套查询出选修了“数据结构”课程的学生学号和姓名;7)使用嵌套查询查询其它系中年龄小于CS系的某个学生的学生姓名、年龄和院系;8)使用ANY、ALL 查询,列出其他院系中比WM系所有学生年龄小的学生的姓名;9)使用集合查询查询选修1号课程同时选修2号课程的同学的学号与姓名;2.以实验数据库为基础数据,利用对象资源管理器创建以下视图:1)创建所有学生学号、姓名及年龄的信息视图v_stu_info2)创建CS系学生基本信息视图v_stu_cs3)创建选修课成绩在80分以上的学生的信息视图v_stu_80,包括学生基本情况及成绩。
3. 以实验数据库为基础数据,请使用T-SQL语句完成以下内容,并将SQL语句写在实验报告册中:1) 创建v_CS视图,包括CS系各学生的学号、姓名及年龄,要求进行修改和插入操作时仍需保证该视图只有CS系的学生;2) 创建v_CS_age20视图,包括CS系学生年龄在20岁以上的基本信息;并保证对视图文本的修改都要符合年龄大于20这个条件。
第五章 SQL语言、查询和视图
——Visual FoxPro 6.0数据库应用基础第二部分数据库操作第五章SQL 语言、查询和视图5.1 SQL语言5.3 视图第四章查询和统计⏹掌握并熟练运用SQL语言⏹掌握视图的概念学习目标数据库应用基础5. 1 SQL语言返回SQL 是结构化查询语言(Structured Query Language ,SQL )的缩写,它是一个通用的,功能极强的关系数据库的标准语言。
它与VFP 的其它表操作命令相独立,即可以独立使用。
如SQL 操作表时,不用USE 命令打开表1. SQL 语言具有以下特点⏹⏹高度非过程化⏹面向集合的操作方式⏹以同一种语法结构提供两种使用方式⏹语言简洁,易学易用2. SQL 语言具有以下功能(1)数据定义功能:用于定义数据表的结构,如创建、修改或删除数据表命令:CREATE 、ALTER 、DROP(2)数据操纵命令:SELECT(3)数据查询功能:用于查询数据命令:INSERT 、UPDATE 、DELETE(4)数据控制功能:用于控制用户对数据表的访问权限等命令:由于VFP 在安全控制方面的缺陷,没提供数据控制命令。
5.1.1数据定义语言SQL 语言使用数据定义语言(Date Definition Language ,简称DDL )实现其数据定义功能,可对数据库用户、基本表、视图、索引进行定义和撤消。
DDL 的命令及功能1.建立表结构命令CREATE TABLE创建数据表时已经打开了一个数据库,则所创建的数据表将自动添加到该数据库中,否则将生成自由表。
【命令】(<字段名1> <字段类型>[<字段宽度> [,小数位]][CHECK <表达式> [ERROR <提示信息>]][PRIMARY KEY/UNIQUE][,<字段名2> …])5.1.1数据定义语言5.1.1数据定义语言【说明】①FREE 指定创建自由表,当数据库没有打开时,不必指定该项.②命令中常见的字段数据类型和字段宽度及小数位数③NULL/NOT NULL 表示是否允许字段值为空值。
实现SQLServer数据库中的视图和查询
2.视图
视图看上去同表似乎一模一样,具有一组命名的 字段和数据项,但它其实是一个虚拟的表,在物理上 并不实际存在。视图是由查询数据库表产生的,它限 制了用户能看到和修改的数据。视图一旦定义后,就 可以和基本表一样被查询、被删除,也可以在一个视 图基础上再定义新的视图。 视图兼有表和查询的特点:与查询相类似的是, 视图可以用来从一个或多个相关联的表或视图中提取 有用信息;与表相类似的是,视图可以用来更新其中 的信息,并将更新结果永久保存在磁盘上。我们可以 用视图使数据暂时从数据库中分离成为游离数据,以 便在主系统之外收集和修改数据。
3、使用DROP VIEW删除视图 删除视图的语法格式如下。 DROP VIEW 视图名1,…,视图名n 使用该语句一次可以删除多个视图。
§4 通过视图访问数据 使用视图管理表中的数据包括插入、更新 和删除三种操作,在操作时要注意以下几点: 修改视图中的数据时,可以对基于两个以 上基表或视图的视图进行修改,但是不能同时 影响两个或者多个基表,每次修改都只能影响 一个基表。 不能修改那些通过计算得到的列,例如年龄 和平均分等。 若在创建视图时定义了 WITH CHECK OPTION选项,那么使用视图修改基表中的数 据时,必须保证修改后的数据满足定义视图的 限制条件。
二、视图的优缺点
当对通过视图看到的数据进行修改时,相应 的基本表的数据也要发生变化,同时,若基本表 的数据发生变化,则这种变化也可以自动地反映 到视图中。 视图有很多优点,主要表现在: 1、视点集中 视图集中即是使用户只关心它感兴趣的某些 特定数据和他们所负责的特定任务。这样通过只 允许用户看到视图中所定义的数据而不是视图引 用表中的数据而提高了数据的安全性。
第6章 数据查询与视图(1)
第6章 数据查询与视图
《 SQL Server 数据库管理与开发》
1SELECT概述
2简单查询
SELECT子句 条件的查询 汇总查询 查询结果排序 查询结果保存 函数名 sum() avg() min() max() count() count(*)
2.3 汇总查询(聚合函数)
功能 对数值型列或计算列求总和 对数值型列或计算列求平均值 返回一个数值列或数值表达式的最小值 返回一个数值列或数值表达式的最大值 返回满足指定的条件的记录的个数 返回找到的行数
3高级查询 4视图 5本章实训 (1) 6本章小结 (1)
6.14】 按年龄从大到小的顺序显示学生的[姓名],[ ],[性 【例6.14】 按年龄从大到小的顺序显示学生的[姓名],[性 ],[年龄 年龄] 别],[年龄]
湖北国土资源职业学院信息工程系
第6章 数据查询与视图
《 SQL Server 数据库管理与开发》
1SELECT概述
基本语法格式 执行方式
1.1 基本语法格式
SELECT 字段列表 2简单查询 目标数据表] [INTO 目标数据表] 3高级查询 源数据表或视图[,...n] [,... FROM 源数据表或视图[,...n] [WHERE 条件表达式] 条件表达式] 4视图 搜索表达式]] 5本章实训(1) [GROUP BY 分组表达式 [HAVING 搜索表达式]] [ORDER BY 排序表达式 [ASC]|[DESC]] 6本章小结(1) 行聚合函数名(表达式)[,...n] )[,... [COMPUTE 行聚合函数名(表达式)[,...n] [,... ...n [BY 表达式 [,...n ]]] SELECT语句的主要功能是: SELECT语句的主要功能是: 语句的主要功能是 FROM列出的数据源表中 找出满足WHERE 列出的数据源表中, WHERE检 从FROM列出的数据源表中,找出满足WHERE检 索条件记录, SELECT子句的字段列表输出查询结 索条件记录,按SELECT子句的字段列表输出查询结 果表,在查询结果表中可进行分组与排序 果表,
视图和查询的区别
视图和查询的区别1:什么是视图2:视图和查询的区别3:视图的优点4:如何创建和管理视图5:如何通过视图修改基本表的数据6:如何通过视图实现数据的安全性A:什么是视图:视图(view):从一个或几个基本表中根据用户需要而做成一个虚表1:视图是虚表,它在存储时只存储视图的定义,而没有存储对应的数据2:视图只在刚刚打开的一瞬间,通过定义从基表中搜集数据,并展现给用户B:视图与查询的区别:视图和查询都是用由sql语句组成,这是他们相同的地方,但是视图和查询有着本质区别: 它们的区别在于:1:存储上的区别:视图存储为数据库设计的一部分,而查询则不是.2:更新限制的要求不一样要注意:因为视图来自于表,所以通过视图可以间接对表进行更新,我们也可以通过update语句对表进行更新,但是对视图和查询更新限制是不同的,以下我们会知道虽然通过视图可以间接更新表但是有很多限制.3:排序结果:通过sql语句,可以对一个表进行排序,而视图则不行.比如:创建一个含有order by子句的视图,看一下可以成功吗?C:视图的优点:为什么有了表还要引入视图呢?这是因为视图具有以下几个优点: 1:能分割数据,简化观点可以通过select和where来定义视图,从而可以分割数据基表中某些对于用户不关心的数据,使用户把注意力集中到所关心的数据列.进一步简化浏览数据工作.2:为数据提供一定的逻辑独立性如果为某一个基表定义一个视图,即使以后基本表的内容的发生改变了也不会影响“视图定义”所得到的数据3:提供自动的安全保护功能视图能像基本表一样授予或撤消访问许可权.4:视图可以间接对表进行更新,因此视图的更新就是表的更新D:视图的创建和管理视图的创建1:通过sql语句格式:create view 视图名 as select 语句试一试:分别创建关于一个表或多个表的视图[因为视图可以来自于多表]2:通过企业管理器说明:1:在完成视图的创立之后,就可以像使用基本表一样来使用视图2:在创建视图时,并非所有的select子查询都可用如:compute和compute by,order by[除非与top一起连用]3:但在查询时,依然都可以用在创建时禁用的select子查询4:在视图创建时,必须为没有标题列指定标题[思考:能否不用select 语句来创建一个视图]视图的删除:1:通过sql语句:drop view 视图名2:通过企业管理器说明:与删除表不同的是,删除视图后只是删除了视图了定义,并没有删除表中的数据.[查看相关性]修改视图的定义1:通过企业管理器2:通过sql语句:格式:alter view 视图名 as 新的select语句浏览视图信息 sp_helptext 视图名 [查看视图创建的语句]E:如何通过视图修改基本表的数据.1:在视图上使用insert语句通过视图插入数据与直接在表中插入数据一样,但视图毕竟不是基本表.因此在进行数据插入时还是有一定的限制1:如果视图上没有包括基本表中属性为not null[不能为空]的列,那么插入操作会因为那些列是null值而失败.2:如果某些列因为某些规则或约束的限制而不能直接接受从视图插入的列时,插入会失败3:如果在视图中包含了使用统计函数的结果,或是包含计算列,则插入操作会失败4:不能在使用了distinct语句的视图中插入值5:不能在使用了group by语句的视图中插入值2:使用update更新视图中的数据1:更新视图与更新表格一样,但是在视图中使用了多个基本表连接的情况下,每次更新操作只能更新来自基本表的一个数据列例如:创建以下视图:create view del asselect 职工号,姓名,部门名称,负责人 from work1,部门where work1.部门编号=部门.部门编号如果再执行下面的语句时:update del set 职工号=\'001\',部门名称=\'wenda\' where 职工号=\'01\'[出现错误]只能够改成:update del set 职工号=\'001\' where 职工号=\'01\' update del set 部门名称=\'wenda\' where 职工号=\'01\' 2:不能在使用了distinct语句的视图中更新值3:不能在使用了group by语句的视图中更新值3:使用delete删除视图中数据.通过视图删除数据最终体现为从基本表中删除数据格式:delete 视图名 [where 条件]说明:当视图由两个以上的基表构成时,不允许删除视图的数据例如:建一个视图kkcreate view kk asselect 职工号,姓名,性别,部门名称from work1,部门where work1.部门编号=部门.部门编号 [试着去删除]使用with check option的视图如果不了解视图定义内容,则常常会发生向视图中输入不符合视图定义的数据的情况.比如:create view xm asselect * from work where 性别=\'男\'完全可以插入insert xm values(\'001\',\'女\',23,\'2400\'....)尽管从意义上来说是不合理的,但是上述语句是正确的.为了防止这种情况的发生,可以使用with check option子句来对插入的或更改的数据进行限制.比如:create view xm asselect * from work where 性别=\'男\' with check option使用schemabinding的视图[使用绑定到构架]我们知道视图是依赖于表,如果在一个表中创建一个视图,今后如果这个表被删除了,则这个视图将不可再用了.为了防止用户删除一个有视图在引用的表,可以在创建视图的时候加上schemabinding关键字.比如:create view 基本工资 with SCHEMABINDINGas select 姓名,性别,基本工资 from dbo.work说明:1:不能使用“*”来创建此类型的视图2:创建此类型的视图时,一定要加上dbo.表名.3:如果在某个表中定义了此类视图,则用户将不能对表的结构进行修改,否则会删除这些绑定4:如果用户对表的结构进行列改名,则会删除绑定而且视图不可用.5:如果用户对表的结构进行列的类型或者大小修改,则会删除绑定但视图可用,此时用户可以删除视图所引用的表.使用with encryption对视图进行加密为了保护创建视图定义的原代码,可以对视图进行加密.比如:create view kk with encryptionas select * from work where 职称=\'经理\'用sp_helptext来查看一下.或用企业管理器查看一下.说明:如果应用此项用户将无法设计视图F:使用视图加强数据的安全一般通过使用视图共有三种途径加强数据的安全性A:对不同用户授予不同的使用权.B:通过使用select子句限制用户对某些底层基表的列的访问C:通过使用where子句限制用户对某些底层基表的行的访问对不同用户授予不同的权限。
数据库实验4_数据库查询与视图
数据库实验4_数据库查询与视图在学⽣选课数据库中完成规定查询,并创建视图。
1.查询线性代数不及格的同学的学号和姓名;SQL语句为:SELECT名单$.学号,姓名FROM名单$,学⽣选课信息和成绩$,课程$WHERE名单$.学号=学⽣选课信息和成绩$.学号AND课程$.课号=学⽣选课信息和成绩$.课号AND 课程$.课程名='线性代数'AND学⽣选课信息和成绩$.成绩<60;执⾏后结果为:2.查询没有选课记录的同学的所有基本信息;SQL语句为:SELECT*FROM名单$WHERE NOTEXISTS(SELECT*FROM学⽣选课信息和成绩$WHERE学号=名单$.学号);执⾏后结果为:3.查询具有简介先修课的课程信息及对应的先修课名;SQL语句为:SELECTFIRST.课号,SECOND.课程名FROM课程$FIRST,课程$SECONDWHEREFIRST.先修课号=SECOND.课号;执⾏后结果如下:4.统计⾼等数学(1)的平均成绩;SQL语句为:SELECT AVG(成绩)FROM学⽣选课信息和成绩$,课程$WHERE学⽣选课信息和成绩$.课号=课程$.课号AND课程$.课程名='⾼等数学(1)'; 执⾏后结果如下:5.统计各门课的选课⼈数;SQL语句为:SELECT课号,COUNT(学号)FROM学⽣选课信息和成绩$GROUPBY课号;执⾏后结果为:6.查询选修5门课以上的学⽣的学号;SQL语句为:SELECT学号FROM学⽣选课信息和成绩$GROUPBY学号HAVING COUNT(*)>5;执⾏后结果为:7.⽤你的学号查询和你⼀个班的同学的学号和姓名;SQL语句为:SELECT学号,姓名FROM名单$WHERE班级IN(SELECT班级FROM名单$WHERE学号='201000800145');执⾏后结果如下:8.查询⾼等数学(1)成绩⽐你⾼出10分以上的同学的姓名和对应成绩;SQL语句为:SELECT姓名,成绩FROM名单$,学⽣选课信息和成绩$WHERE名单$.学号=学⽣选课信息和成绩$.学号AND学⽣选课信息和成绩$.课号='82006010'AND成绩>(SELECT成绩+10FROM学⽣选课信息和成绩$,课程$WHERE学⽣选课信息和成绩$.课号=课程$.课号AND课程$.课程名='⾼等数学(1)' AND学⽣选课信息和成绩$.学号='201000800145')执⾏后结果为:9.找到每门课获得最⾼成绩的同学的学号、姓名、课名和成绩;选做。
数据库系统基础讲义第07讲SQL语言之查询与视图
与多重循环 的原则是否 一样呢?
注意:相关子查询只能由外层向内层传递参数,而不能反之;这也称为变 量的作用域原则。
战德臣 教授
示例:找出工资最低的教师姓名
Select Tname From Teacher 利用元组演算 怎样表达? Where Salary <= all ( Select Salary From Teacher );
示例:找出001号课成绩不是最高的所有学生的学号
Select S# From SC Score < some ( Select Score From SC Where C# = “001” ); Where C# = “001” and
数据库系统之二 --数据库语言-SQL
战德臣哈尔滨工业大学 教授博士生导师 黑龙江省教学名师 教育部大学计算机课程教学指导委员会委员
Research Center on Intelligent Computing for Enterprises & Services, Harbin Institute of Technology
战德臣 教授
内层查询
非相关子查询:内层查询独立进行,没有涉及任何外层查询相关
信息的子查询 前面的子查询示例都是非相关子查询
利用SQL语言表达复杂查询—(NOT) IN子查询 (4) 相关子查询
战德臣 教授
相关子查询:内层查询需要依靠外层查询的某些参量作为限定条件
才能进行的子查询 外层向内层传递的参量需要使用外层的表名或表别名来限定 示例:求学过001号课程的同学的姓名
Visual FoxPro VF 第7章 查询与视图(1)
• 注意:视图与查询最大的区别:视图是可 更新的,而查询不可以; • 查询有“查询去向”功能,可视图没有。
• 05-4考题: • 19、在Visual FoxPro中,关于查询和视图的正确描述 是______。 • A、查询是一个预先定义好的SQL SELECT语句 文件 • B、视图是一个预先定义好的SQL SELECT语句 文件 • C、查询和视图是同一种文件,只是名称不同 • D、查询和视图都是一个存储数据的表 • 30、在Visual FoxPro中,以下关于视图描述中错误的 是______。 • A、通过视图可以对表进行查询 • B、通过视图可以对表进行更新 • C、视图是一个虚表 • D、视图就是一种查询
• 33、删除视图myview的命令是______。 • A、DELETE myview VIEW • B、DELETE myview • C、DROP myview VIEW • D、DROP VIEW myview • 07-4考题: • 15、在Visual FoxPro中,以下关于查询的描述正 确的是______。 • A、不能用自由表建立查询 • B、只能用自由表建立查询 • C、不能用数据库表建立查询 • D、可以用数据库表和自由表建立查询
• 2、视图
• 如:CREATE VIEW e_w AS SELECT 职 工号,仓库号 FROM 职工
– 视图是一个定定的虚拟表,可以是本地的、远程的 或带参数的。 – 视图可引用一个或多个表,或引用其他视图。 – 视图是可更新的。 – 在关系数据库中,视图也称作窗口,即视图是操作 表的窗口,可以把它看作是从表中派生出来的虚表 (依赖于表,不独立存在)。 – 视图是数据库中的一个特有功能,只有在包含视图 的数据库打开时,才能使用视图。 – 视图一经建立就基本可以像基本表一样使用,适用 于基本表的命令基本都可以用于视图。 – 视图的建立:
视图与查询的区别
一、视图与查询的区别功能不同。
视图可以更新字段内容并返回原表,而查询文件中的记录数据不能修改。
这是视图与查询的本质区别。
归属不同。
视图不是一个独立的文件,它保存在数据库中。
查询文件是一个独立的文件,不属于数据库。
访问限制不同。
视图的数据来源可以是本地数据源,也可以是远程数据源,而查询不能访问远程数据源。
输出去向不同。
视图只能当表使用,而查询可以选择多种查询去向,如表、图表、报表、标签等多种形式。
使用方法不同。
视图可以作为数据源被引用,而查询不能被引用。
使用方式不同。
视图只有所属的数据库被打开时才能使用。
而查询可在“命令”窗口中执行。
二、数据库在创建关系之前,要关联的表之间必须有公共的字段和索引。
在数据库中创建的关系称为“永久关系”,之所以成为永久关系,是因为这种表与表之间的关系作为数据库的一部分存储在数据库文件中。
两个建立了关系的表可以分为父表和子表。
显然,一个父亲可以有一个或多个子女,而每个子表只能有一个父表。
这样两个表之间的关系就由子表在建立关系使用的索引类型决定了。
如果子表索引类型为[主索引]或[候选索引],那么,两表之间就是一对一关系。
否则,若子表索引类型为[普通索引]或[唯一索引],那么,两表间就是一对多关系。
而作为父表来说,它在建立关系时使用的索引类型就只能是[主索引]或[候选索引]。
三、查询在多表查询中,可以使用数据库表、自由表、本地视图或远程视图的任意组合。
在查询中,我们在表之间建立的联接与数据库中表之间的关系是不同的。
在查询中,表之间建立的联接是以选择标准存在,不会象数据库中表之间的持续关系那样持续保存下来,也不必建立在索引的基础上。
只有当字段的大小相等,且数据类型相同时才能建立联接。
同表之间的永久关系一样,一个表不能同时为两个父表的子表,也不能同时为两个子表的父表。
数据库__VFP6第4章查询与视图
图4-15 查询设计器界面
(3)查询参数的设置 第一节 查询 ①确定输出的字段。在图4-15中的“可用字段”列表框中显示了上部窗 口中表的所有字段名称,通过“添加”或“全部添加”将“可用字段” 中所选择的字段移到“选定字段”列表框中。在本例中,B_xsxx表中除 szbj、xsjg、xspy等三个字段不选外其余全选,B_bjxx表中选择bjmc, B_dqxx表中选择dqmc ②设置联接条件 ③查询结果的排序。如果需要对查询的结果按一定的顺序排列,则可以 选择“排序依据”选项卡,以决定排序的依据。该选项卡如图4-16所示 。
第一节
图4-2 查询向导步骤之2 查询 查询向导步骤之2
第一节 查询 (4)步骤2:关联表
通常查询向导会自动查找两个表之间相匹配的字段 并显示在第二步的两个列表框中, 并显示在第二步的两个列表框中 , 如果这种关系正是 所需要的, 可以直接单击“ 添加” 按钮。 所需要的 , 可以直接单击 “ 添加 ” 按钮 。 如果在表之 间没有相匹配的字段, 就需要手工建立, 间没有相匹配的字段 , 就需要手工建立 , 只要分别在 两个下拉列表框中选取相应的字段即可。 两个下拉列表框中选取相应的字段即可。
图4-16 排序依据选项卡
第一节 查询 ④查询条件的设置。在“筛选”选项卡中可以设定查询的
条件,例如可以查询所有男同学的情况。“筛选”选项卡 如图4-17。
图4-17 筛选选项卡
⑤其他查询参数的设置 查询参数主要包括以上四项,其 他还有“分组依据”和“杂项”两个选项。
(4)查询结果的去向 第一节 查询
在查询设计的过程中,为了查看查询的结果, 可以随时单击“运行”按钮,VFP就会在屏幕上显 示查询的结果记录。在默认情况下,查询的结果直 接输出到屏幕上而且是不保存的。如果想改变查询 结果的去向,可以单击“查询设计器”工具栏中的 “查询去向”按钮,在图4-18所示的查询去向对话 框中选择不同的查询去向。
实现SQL Server数据库中的视图和查询
§3 管理视图 1、使用系统存储过程查看视图信息
sp_help 表/视图 sp_helptext 表/视图 sp_depends 表/视图
2、使用T-SQL语句修改视图 ALTER VIEW语句的语法格式为: ALTER VIEW [<数据库名>.][<所有者>.]视图 名[(列名[,...n])] [WITH {ENCRYPTION|SCHEMABINDING|VIEW_METADATA}] AS SELECT查询语句 [WITH CHECK OPTION] 参数说明同CREATE VIEW相同。
(5)在CREATE VIEW语句中,对于SELECT 查询语句有如下限制: 创建视图的用户必须对该视图所参照或引用 的表或视图具有适当的权限。 在查询语句中,不能包含ORDER BY(如果 要包含的话SELECT子句中要用TOP n [percent])、 COMPUTE或COMPUTE BY关键字。也不能包 含INTO关键字。 不能在临时表中定义视图(不能引用临时表)。
FROM { 表名|视图名 } [ ,...n ]
当有多个数据源时,可以使用逗号“,”分隔, 但是最多只能有16个数据源。数据源也可以像 列一样指定别名,该别名只在当前的SELECT语 句中起作用,方法为:数据源名 AS 别名,或 者数据源名 别名。指定别名的好处在于以较短 的名字代替原本见名知意的长名。
(8)SCHEMABINDING:将视图绑定到架 构上。指定 SCHEMABINDING 时,SELECT 查询语句必须包含所引用的表、视图或用户定 义函数的两部分名称 (owner.object)。不能除去 参与用架构绑定子句创建的视图中的表或视图, 除非该视图已被除去或更改,不再具有架构绑 定。否则,SQL Server 会产生错误。另外,如 果对参与具有架构绑定的视图的表执行 ALTER TABLE 语句,而这些语句又会影响该架构绑定 视图的定义,则这些语句将会失况: ①只能在当前数据库中创建视图。 ②视图中最多只能引用1024列。 ③如果视图引用的基表或者视图被删除, 则该视图不能再被使用,直到创建新的基表或 者视图。 ④如果视图中某一列是函数、数学表达式、 常量或者来自多个表的列名相同,则必须为列 定义名称。
第9章视图与查询操作
二、视图的分类
本地视图:直接从本地计算机的数据库表或 本地视图 其他视图中提取数据。 远程视图:可从支持开放数据库连接 远程视图 (ODBC)的远程数据源(例如网络服务器) 中提取数据。
三、视图的优点
提供数据库使用的灵活性 减少用户对数据库物理结构的依赖。 可支持网络应用。
视图与查询的比较; 1、功能不同 功能不同:视图可以更新记录内容并返回源表, 功能不同 而查询中记录数据不能被修改。 从属不同:视图必须从属于某一个数据库,而查 2、从属不同 从属不同 询是一个独立的文件,它不从属于某一个数据库。 3、访问范围不同 访问范围不同:视图可以访问本地数据源,又可 访问范围不同 以访问远程数据源,而查询只能访问本地数据源。 输出方式不同:视图只能输出到数据表中,而查 4、输出方式不同 输出方式不同 关于计算机系 、建立一个本地视图, 学生的基本信息。 学生的基本信息。 具体实现的方法如下: 具体实现的方法如下: 1、打开“教学数据库” 、打开“教学数据库” 2、打开“视图设计器” 、打开“视图设计器” 3、在“视图设计器”中进行相关设计: 、 视图设计器”中进行相关设计: 1)添加表或视图 ) 2)设计视图中的字段 ) 3)设置筛选的条件 ) 4)设置更新条件 ) 5)保存视图 ) 6)运行视图 )
性别字段表达4分组依据选项卡设置5保存查询6运行查询返回视图的建立与维护视图的建立与维护p148p148152152一视图的定义二视图的分类三视图的特点优点四视图的创建返回一视图的定义一视图的定义视图是在数据表的基础上创建的一种虚拟视图中的数据是按照用户指定的条件从已有的数据库表或其他视图中抽取而来这些数据在数据库中并不另加存储而是仅在该数据库的数据字典中存储这个视图的定义
9、统计每一年龄组选修课程的学生人数。 select 年龄,count(distinct student.学号); from student,sc; where student.学号=sc.学号; group by 年龄;
什么是视图视图的作用
什么是视图视图的作用视图是指计算机数据库中的视图,是一个虚拟表,其内容由查询定义。
同真实的表一样,视图包含一系列带有名称的列和行数据。
以下是由店铺整理关于什么是视图的内容,希望大家喜欢!视图的含义从用户角度来看,一个视图是从一个特定的角度来查看数据库中的数据。
从数据库系统内部来看,一个视图是由SELECT语句组成的查询定义的虚拟表。
从数据库系统内部来看,视图是由一张或多张表中的数据组成的,从数据库系统外部来看,视图就如同一张表一样,对表能够进行的一般操作都可以应用于视图,例如查询,插入,修改,删除操作等。
视图是一个虚拟表,其内容由查询定义。
同真实的表一样,视图的作用类似于筛选。
定义视图的筛选可以来自当前或其它数据库的一个或多个表,或者其它视图。
分布式查询也可用于定义使用多个异类源数据的视图。
视图是存储在数据库中的查询的SQL 语句,它主要出于两种原因:安全原因,视图可以隐藏一些数据,如:社会保险基金表,可以用视图只显示姓名,地址,而不显示社会保险号和工资数等,另一原因是可使复杂的查询易于理解和使用。
视图:查看图形或文档的方式。
视图一经定义便存储在数据库中,与其相对应的数据并没有像表那样又在数据库中再存储一份,通过视图看到的数据只是存放在基本表中的数据。
对视图的操作与对表的操作一样,可以对其进行查询、修改(有一定的限制)、删除。
当对通过视图看到的数据进行修改时,相应的基本表的数据也要发生变化,同时,若基本表的数据发生变化,则这种变化也可以自动地反映到视图中。
视图的种类区别Oracle数据库视图的种类和区别关系视图:Oracle视图是作为数据库对象存在的,因此,创建之后也可以通过工具或数据字典来查看视图的相关信息。
这是大家常用的视图,如:create view 视图。
内嵌视图:在from语句中的可以把表改成一个子查询,如:select a、id ,b、id from emp a,(select id from dept) b where a、id=b、id内嵌视图不属于任何用户,也不是对象,内嵌视图是子查询的一种,可以与数据表、视图一样作为查询语句的数据源存在,但在形式上有较大的区别,内嵌视图不必使用create view命令进行创建,因此,在数据字典中也无法获得相应信息。
数据库表和视图区别理解
数据库表和视图区别理解
⼀,表
1>,表是以每秒⾁眼看不见的速度刷新的,每次插⼊数据,修改数据,检索数据都是,刷新表状态的,否则你看到的就是不准确的数据
2>,表是⽤来增删改的,已经不是⽤来查的了,除⾮你的访问密度⼩
⼆,视图
1>,视图和表的机制完全不同,视图是被动更新,只有删除,修改,插⼊的时候才刷新,⽽且不是针对表,是它⾃⼰copy了数据,在内存给你看
2>,视图对内存的要求⼤,但是换来的是读写分离,避免⾼并发的死锁问题
3>,合理的运⽤视图,可以把数据库的负担降低很多,⼀般情况下是⼤量的查询造成的死锁,要解决锁,就需要转移查询的主体
4>,创建视图也有个忌讳,不要把内容很⼤的字段放进去⽐如⽂章内容,这样会消耗你很多内存空间,⽽且查的慢,这些部分只能是分拆成查视图和查表了。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
实验三:数据库的查询和视图
实验目的:
加深对嵌套查询语句的理解,熟练掌握数据查询中的分组、统计、计算和集合的操作方法;掌握视图的用法,加深对视图作用的理解。
实验内容:
使用IN、比较符、ANY或ALL和EXISTS操作符和聚集函数、分组函数、集合函数进行查询,进行嵌套查询操作;创建、修改和删除视图,利用视图进行查询。
实验步骤:
一. 使用带IN谓词的子查询
1.查询与’刘晨’在同一个系学习的学生的信息:
2.查询选修了课程名为’信息系统’的学生的学号和姓名:
3.查询选修了课程’1’和课程’2’的学生的学号:
二. 使用带比较运算的子查询
4.查询比’刘晨’年龄小的所有学生的信息:
三. 使用带Any, All谓词的子查询
5.查询其他系中比信息系(IS)某一学生年龄小的学生姓名和年龄;
6.查询其他系中比信息系(IS)学生年龄都小的学生姓名和年龄:
7.查询与计算机系(CS)系所有学生的年龄均不同的学生学号, 姓名和年龄:
四. 使用带Exists谓词的子查询和相关子查询
8.查询与其他所有学生年龄均不同的学生学号, 姓名和年龄:
9.查询所有选修了1号课程的学生姓名:
10.查询没有选修了1号课程的学生姓名:
11.查询选修了全部课程的学生姓名:
11. 查询至少选修了学生95002选修的全部课程的学生的学号:
12. 求没有人选修的课程号cno和cnamecname:
13*. 查询满足条件的(sno,cno)对, 其中该学号的学生没有选修该课程号cno的课程14*. 查询每个学生的课程成绩最高的成绩信息(sno,cno,grade):
五. 使用聚集函数:
15. 计算1号课程的学生的平均成绩, 最高分和最低分:
16. 查询’信息系’(IS)学生”数据结构”课程的平均成绩:
17*. 查询每个学生的课程成绩最高的成绩信息(sno,cno,grade):
18*. 求成绩低于该门课程平均成绩的学生的成绩信息(sno,cno,grade)
六. 分组查询
19. 查询各系的学生的人数并按人数从多到少排序:
20. 查询各系的男女生学生总数, 并按系别,升序排列, 女生排在前:
21. 查询选修了3门课程已上的学生的学号和姓名:
22. 查询每个学生所选课程的平均成绩, 最高分, 最低分,和选课门数:
23. 查询至少选修了2门课程的学生的平均成绩:
24. 查询平均分超过80分的学生的学号和平均分:
25. 查询”信息系”(IS)中选修了5门课程以上的学生的学号:
七集合查询
26. 查询数学系和信息系的学生的信息;
27. 查询选修了1号课程或2号课程的学生的学号:
视图部分:
说明:对视图的创建、修改和删除均可在可视化界面下操作。
在SQL Server企业管理器中,依次选择数据库――XSGL――视图――鼠标右击――
新建视图。
然后通过单击按钮或右击鼠标第一格的空白区域,选择弹出菜单中的“添加表”。
然后拖拽主键到外键,建立关联,点击字段左边的方框选择输出字段。
图5-1
仅以命令方式来操作:
一、视图的创建:
1.创建信息系学生信息的视图:
2. 创建信息系选修了1号课程的学生的视图:
3. 建立信息系选修了1号课程且成绩在90分以上的学生的视图:
4. 创建一个反映学生出生年份的视图:
5. 将所有女生的记录定义为一个视图:
6. 将所有学生的学号和他的平均成绩定义为一个视图:
二、视图结构的修改:
6. 将视图F_student修改为信息系的所有女士的视图
说明: 视图结构的修改的AS 后的Select语句与创建视图的完全一致, 引入结构修改的目的是为了避免与视图相关的数据库对象的变换, 如触发器, 关联等
三、查询视图
7. 在信息系的学生视图中查询年龄小于20岁的学生:
8. 查询信息系选修了1号课程的学生:
9. 在视图S_G中查询平均成绩在90分以上的学生的学号和平均成绩:
四、更新视图:
10.将信息系学生视图IS_Student中学号为”95002”的学生姓名改为”刘辰”:
11. 向信息系学生视图IS_Student中插入一个新的学生记录, 学号为95029,姓名为”赵新”, 年龄为20岁:
12. 删除信息系学生视图IS_Student中学号为95004的学生的记录:
五、删除视图:
13. 删除视图IS_S1:
drop view IS_S1。