数据库查询视图
实现SQLServer数据库中的视图和查询
![实现SQLServer数据库中的视图和查询](https://img.taocdn.com/s3/m/ba5a98364431b90d6c85c762.png)
2.视图
视图看上去同表似乎一模一样,具有一组命名的 字段和数据项,但它其实是一个虚拟的表,在物理上 并不实际存在。视图是由查询数据库表产生的,它限 制了用户能看到和修改的数据。视图一旦定义后,就 可以和基本表一样被查询、被删除,也可以在一个视 图基础上再定义新的视图。 视图兼有表和查询的特点:与查询相类似的是, 视图可以用来从一个或多个相关联的表或视图中提取 有用信息;与表相类似的是,视图可以用来更新其中 的信息,并将更新结果永久保存在磁盘上。我们可以 用视图使数据暂时从数据库中分离成为游离数据,以 便在主系统之外收集和修改数据。
3、使用DROP VIEW删除视图 删除视图的语法格式如下。 DROP VIEW 视图名1,…,视图名n 使用该语句一次可以删除多个视图。
§4 通过视图访问数据 使用视图管理表中的数据包括插入、更新 和删除三种操作,在操作时要注意以下几点: 修改视图中的数据时,可以对基于两个以 上基表或视图的视图进行修改,但是不能同时 影响两个或者多个基表,每次修改都只能影响 一个基表。 不能修改那些通过计算得到的列,例如年龄 和平均分等。 若在创建视图时定义了 WITH CHECK OPTION选项,那么使用视图修改基表中的数 据时,必须保证修改后的数据满足定义视图的 限制条件。
二、视图的优缺点
当对通过视图看到的数据进行修改时,相应 的基本表的数据也要发生变化,同时,若基本表 的数据发生变化,则这种变化也可以自动地反映 到视图中。 视图有很多优点,主要表现在: 1、视点集中 视图集中即是使用户只关心它感兴趣的某些 特定数据和他们所负责的特定任务。这样通过只 允许用户看到视图中所定义的数据而不是视图引 用表中的数据而提高了数据的安全性。
数据库 PPT6第六章
![数据库 PPT6第六章](https://img.taocdn.com/s3/m/cc9c95e9bb4cf7ec4afed0d9.png)
计器中时,会自动弹出【连接条件】对话框,用于设置数据表之间
的关联。本例中,在【连接条件】对话框的左右两个下拉列表中分
别选择“Student.学号”和“Score.学号”两个字段,如图6.11所 示。这一步也可以在【查询设计器】对话框的【连接】选项卡中完
成。
上一页 下一页 返回
6.2
查询
步骤4:字段选取。在【查询设计器】对话框的【字段】选项
“学号”,单击
按钮将其移入【选定字段】列表框,用同样的
方法将“姓名”、“班级”、“性别”、“年龄”移入【选定字段】 列表框;完成后单击【下一步】按钮,如图6.3所示。
步骤4:筛选记录,输入查询的筛选条件。在【查询向导】对
筛选记录”中,根据要求在【字段】下拉列表中选
话框的“步骤3
择“STUDENT.系别”,在【操作符】下拉列表中选择“等于”,在 【值】文本框中输入“计算机”;完成后单击【下一步】按钮,如 图6.4所示。
的“步骤2
号”,拖放到【坐标轴】文本框,选择“成绩”列表项拖放到【数 据系列】列表框,单击【下一步】按钮,如图6.18所示。
步骤4:选择图形样式。在【图形向导】对话框的“步骤3
选
择图形样式”中,选择需要的图形样式,本例中选择“三维柱形图”
(上排右一),如图6.19所示。
上一页 下一页 返回
6.2
建立查询后,可以单击【程序】菜单中的【运行】命令,在打
开的【运行】对话框中选择需要运行的查询文件:JSJA.QPR,如图 6.8所示。单击运行按钮“”执行查询,结果如图6.9所示。
上一页 下一页 返回
6.2
查询
2. 使用查询设计器建立查询 【例6.11】 查询学生陈腾云各门功课的成绩,显示学号、姓
常用查询Oracle的表,视图,存储过程,用户等SQL命令
![常用查询Oracle的表,视图,存储过程,用户等SQL命令](https://img.taocdn.com/s3/m/bd9c2114a9114431b90d6c85ec3a87c240288ace.png)
常⽤查询Oracle的表,视图,存储过程,⽤户等SQL命令有时候需要导出某⽤户下的所有table、view、sequence、trigger等信息,下⾯的SQL可以将这些信息select出来:select * from user_tables;select * from user_views;select * from user_sequences;select * from user_triggers;查看当前⽤户的缺省表空间 SQL>select username,default_tablespace from user_users; 查看当前⽤户的⾓⾊ SQL>select * from user_role_privs; 查看当前⽤户的系统权限和表级权限 SQL>select * from user_sys_privs; SQL>select * from user_tab_privs; 查看⽤户下所有的表 SQL>select * from user_tables;1、⽤户 查看当前⽤户的缺省表空间 SQL>select username,default_tablespace from user_users; 查看当前⽤户的⾓⾊ SQL>select * from user_role_privs; 查看当前⽤户的系统权限和表级权限 SQL>select * from user_sys_privs; SQL>select * from user_tab_privs; 显⽰当前会话所具有的权限 SQL>select * from session_privs; 显⽰指定⽤户所具有的系统权限 SQL>select * from dba_sys_privs where grantee=’GAME’;2、表 查看⽤户下所有的表 SQL>select * from user_tables; 查看名称包含log字符的表 SQL>select object_name,object_id from user_objects where instr(object_name,’LOG’)>0; 查看某表的创建时间 SQL>select object_name,created from user_objects where object_name=upper(‘&table_name’); 查看某表的⼤⼩ SQL>select sum(bytes)/(1024*1024) as “size(M)” from user_segments where segment_name=upper(‘&table_name’); 查看放在ORACLE的内存区⾥的表 SQL>select table_name,cache from user_tables where instr(cache,’Y')>0;3、索引 查看索引个数和类别 SQL>select index_name,index_type,table_name from user_indexes order by table_name; 查看索引被索引的字段 SQL>select * from user_ind_columns where index_name=upper(‘&index_name’); 查看索引的⼤⼩ SQL>select sum(bytes)/(1024*1024) as “size(M)” from user_segments where segment_name=upper(‘&index_name’);4、序列号 查看序列号,last_number是当前值 SQL>select * from user_sequences;5、视图 查看视图的名称 SQL>select view_name from user_views; 查看创建视图的select语句 SQL>set view_name,text_length from user_views; SQL>set long 2000; 说明:可以根据视图的text_length值设定set long 的⼤⼩ SQL>select text from user_views where view_name=upper(‘&view_name’);6、同义词 查看同义词的名称 SQL>select * from user_synonyms;7、约束条件 查看某表的约束条件 SQL>select constraint_name, constraint_type,search_condition, r_constraint_name from user_constraints where table_name = upper(‘&table_name’); SQL>select c.constraint_name,c.constraint_type,cc.column_name from user_constraints c,user_cons_columns cc where c.owner = upper(‘&table_owner’) and c.table_name = upper(‘&table_name’) and c.owner = cc.owner and c.constraint_name = cc.constraint_name order by cc.position;8、存储函数和过程 查看函数和过程的状态 SQL>select object_name,status from user_objects where object_type=’FUNCTION’; SQL>select object_name,status from user_objects where object_type=’PROCEDURE’; 查看函数和过程的源代码 SQL>select text from all_source where owner=user and name=upper(‘&plsql_name’);。
oracle查询视图sql语句
![oracle查询视图sql语句](https://img.taocdn.com/s3/m/0def11ed5ebfc77da26925c52cc58bd63186937d.png)
oracle查询视图sql语句Oracle数据库查询视图(Views)是一种可以把一张表中的数据提取出来并根据不同的筛选条件进行展示的功能。
它是Oracle数据库及其他大多数关系型数据库管理系统的主要功能之一。
视图可以用来查询数据库中的数据,提供更加清晰、方便的结果。
本文将从视图的定义和用处、构建视图的SQL语句构造和使用步骤四个方面来讲解Oracle查询视图的SQL语句。
一、视图的定义和用处视图是一种通过单独的一条SQL语句从表中提取数据的一种特殊方式,它可以看作一个虚拟表,是Oracle数据库中一种重要的功能,它可以安全而有效地把多张表中的数据汇总到一张表或视图中,使得数据存取更加方便、快捷。
视图带来了便利:1、可以给用户提供更合理的数据存取界面,可以把复杂的表和表之间的关系转化成一个简单的视图或表。
2、可以保证安全,可以利用视图的特性保证基本表的安全,视图可以按照设计者的要求隐藏部分数据,提高数据的安全性。
3、可以提供表的相关性,可以通过创建视图来查看数据库中不同表之间的数据细节,从而帮助我们了解数据库中不同表之间的相关活动。
二、构建视图的SQL语句构造1、用SQL命令 CREATE VIEW建视图,CREATE VIEW句的格式为: CREATE VIEW view_name ASSELECT column1,column2…FROM table_nameWHERE [condition];2、用SQL语句 DROP VIEW除视图,DROP VIEW句的格式为:DROP VIEW view_name;3、用SQL语句 ALTER VIEW改视图,ALTER VIEW句的格式为: ALTER VIEW view_name ASSELECT column1,column2…FROM table_nameWHERE [condition];三、使用步骤在使用 Oracle询视图SQL语句时,可以按照以下步骤进行:1、利用CREATE VIEW语句创建一个视图,并为其设置标准名称。
数据库的查询和视图
![数据库的查询和视图](https://img.taocdn.com/s3/m/aa8910e9aeaad1f346933f64.png)
4.替换查询结果中的数据
在对表进行查询时,有时希望对所查询的某些列得到的是一种概念而不是具 体的数据。 例如,查询XSB表的总学分,希望知道的是学习的总体情况,这时,就可以用 等级来替换总学分的具体数字。 要替换查询结果中的数据,则要使用查询中的CASE表达式,格式为 CASE WHEN 条件1 THEN 表达式1 WHEN 条件2 THEN 表达式2 …… ELSE 表达式 END
T1 T2 T1 T2 T1 T2
1
A
6
F
2
B
表4.5 B表
T3 1 T4 3 T5 M T3 2 T4 0 T5 N
表4.6 A B F
T1
1 2
T2
A B
T3
1 2
T4
3 0
T5
M NBiblioteka 数据库应用中最常用的是“自然连接”。进行自然连接运算要求两个表有共同 属性(列),自然连接运算的结果表是在参与操作的两个表的共同属性上进行等值 连接后,再去除重复的属性后所得的新表。自然连接运算记为 ,其中,R和S是参与 运算的两个表。 例如,若表A和B分别如表4.7和表4.8所示,则 如表4.9所示。 表4.7 A表
数据库__VFP6第4章查询与视图
![数据库__VFP6第4章查询与视图](https://img.taocdn.com/s3/m/89398f04e87101f69e31957a.png)
图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实用教程(第三版)实验4_数据库的查询和视图
![SQL_Server实用教程(第三版)实验4_数据库的查询和视图](https://img.taocdn.com/s3/m/253d463d5a8102d276a22f6c.png)
实验四数据库的查询和视图T4.1 数据库的查询1.目的与要求(1)掌握select语句的基本语法;(2)掌握子查询的表示(3)掌握连接查询的表示(4)掌握select语句的group by子句的作用和使用方法(5)掌握select语句的order by子句的作用和使用方法2 实验准备(1)了解SELECT语句的基本语法格式;(2)了解SELECT语句的执行方法;(3)了解子查询的表示方法;(4)了解连接查询的表示;(5)了解SELECT语句的GROUPBY子句的作用和使用方法;(6)了解SELECT语句的ORDERBY子句的作用;3实验内容SELECT语句的基本使用。
①对于实验2给出的数据库表结构,查询每个雇员的所有数据。
新建一个查询,在查询分析器中输入如下语句并执行:USEYGGLGOSELECT *FROM Employees【思考与练习】用SELECT语句查询Departments和Salary表中所有的数据信息。
用SELECT语句查询Employees表中每个雇员的地址和电话。
新建一个查询,在查询分析器中输入如下语句并执行:Use YGGLGOSELECT Address PhoneNumberFROM Employees【思考与练习】a.用SELECT语句查询Deparments和Salary表的一列或若干列。
b.查询Employees表中的部门号和性别,要求使用DISTINCT消除重复行。
c.查询EmployeeID为000001的雇员的地址和电话。
Use YGGLGOSELECT Address PhoneNumberFROM EmployeesWHERE EmployeeID=’000001’【思考与练习】a.查询月收入高于2000元的员工号码。
b.查询1970年以后出生的员工的姓名和住址。
c.查询所有财务部的员工的号码和姓名。
查询Employees表中女雇员的地址和电话,使用AS子句将结果中各列的标题分别指定为地址、电话。
oracle查询视图sql语句
![oracle查询视图sql语句](https://img.taocdn.com/s3/m/0c760bf2d05abe23482fb4daa58da0116d171f70.png)
oracle查询视图sql语句在Oracle数据库中,查询视图SQL语句可以帮助我们快速查询出符合条件的数据。
它可以实现检索出表中所有字段或者指定字段,筛选出满足条件的数据,有助于我们快速查找所需数据,更有助于数据分析和报表制作。
本文将介绍Oracle查询视图SQL语句的语法及具体应用,以及相关技巧,从而帮助读者更好的使用Oracle查询视图的SQL语句。
一、Oracle查询视图的SQL语句1.法Oracle查询视图的SQL语句的基本语法为:SELECT [字段列表]FROM图名[WHERE件][GROUP BY段][HAVING件][ORDER BY段][LIMIT数][OFFSET移量]①字段列表:SELECT子句中使用有逗号分隔的字段名称,如果为空,表示查询出所有字段②视图名:包含有查询视图的名称,多个视图可使用JOIN关键字进行连接③WHERE条件:查询条件,可以使用各种比较运算符和逻辑运算符进行条件组合④GROUP BY字段:分组字段,使用逗号分隔多个字段⑤HAVING条件:分组条件,和WHERE条件一样,也可以使用各种比较运算符和逻辑运算符进行组合⑥ORDER BY字段:排序字段,使用有逗号分隔的字段名称或字段序号,DESC表示降序,ASC表示升序⑦LIMIT行数:限制返回行数,指定查询结果的最大行数⑧OFFSET偏移量:偏移量,指定返回结果从查询结果的第几行开始2.体应用(1)索表中所有字段:SELECT * FROM图名;(2)索指定字段:SELECT段1,段2,段3 FROM图名;(3)选数据:SELECT段1,段2,段3 FROM图名 WHERE件;(4)组统计:SELECT段1,段2,合函数(字段3) FROM图名 GROUP BY段1,段2;(5)合筛选:SELECT段1,段2,合函数(字段3) FROM图名 WHERE 件 GROUP BY段1,段2 HAVING件;(6)序:SELECT段1,段2,段3 FROM图名 ORDER BY段1 ASC,段2 DESC;(7)页:SELECT段1,段2,段3 FROM图名 LIMIT 10 OFFSET 20;三、Oracle查询视图的技巧1.化复杂查询通过JOIN和子查询,可以将复杂的查询变得简单并提高查询性能。
实现SQL Server数据库中的视图和查询
![实现SQL Server数据库中的视图和查询](https://img.taocdn.com/s3/m/915203140b4e767f5acfce24.png)
(6)WITH CHECK OPT须符合由 SELECT查询语句设置的准则。通过视图修改 数据行时,WITH CHECK OPTION 可确保提 交修改后,仍可通过视图看到修改的数据。 ( 7 ) WITH ENCRYPTION : 表 示 SQL Server 加密包含 CREATE VIEW 语句文本的 系统表列。使用 WITH ENCRYPTION 可防止 将视图作为 SQL Server 复制的一部分发布。
(5)在CREATE VIEW语句中,对于SELECT 查询语句有如下限制: 创建视图的用户必须对该视图所参照或引用 的表或视图具有适当的权限。 在查询语句中,不能包含ORDER BY(如果 要包含的话SELECT子句中要用TOP n [percent])、 COMPUTE或COMPUTE BY关键字。也不能包 含INTO关键字。 不能在临时表中定义视图(不能引用临时表)。
FROM { 表名|视图名 } [ ,...n ]
当有多个数据源时,可以使用逗号“,”分隔, 但是最多只能有16个数据源。数据源也可以像 列一样指定别名,该别名只在当前的SELECT语 句中起作用,方法为:数据源名 AS 别名,或 者数据源名 别名。指定别名的好处在于以较短 的名字代替原本见名知意的长名。
二、使用指定的列 select 列名1,列名2,……,列名n from 表名/视图名 返回from中指定的表中的指定列。
三、使用TOP关键字 select top n [percent] 列名
四、使用DISTINCT关键字 使用DISTINCT关键字时, 1、无论遇到多少个空值,只返回一个。 2、表达式只包含一个列名,且不能包含算术 表达式。 3、不能包含text、ntext和image类型字段。 4、是sum、avg和count的可选关键字。
《Visual FoxPro 6.0数据库与程序设计》课件 第4章 查询和视图(电子版)
![《Visual FoxPro 6.0数据库与程序设计》课件 第4章 查询和视图(电子版)](https://img.taocdn.com/s3/m/ca64642a192e45361066f549.png)
利用查询设计器得到的查询文件是一个文本文件,用户可 以查看其内容。 打开查询设计器,选择“查询|查看SQL”命令,打开一个 只读窗口,其中显示了一条SQL语句,它包含了用户创建这个查 询的所有信息。
18
4.2.1 视图的概念
通过视图不仅可以从多个表中提取数据,还可以在改变视
图数据后,把更新结果送回到数据源表中。 视图不能以自由表文件的形式单独存在,它必须依赖于某 个数据库,并且只有在打开相关的数据库之后,才能创建和使
(6)运行查询,获得查询结果。
4
4.1.2 创建查询
1. 启动查询设计器 (1)项目管理器:选择 “查询”数据项,单击“新建”按钮, 出现“新建查询”对话框,选择“新建查询”命令,打开查询 设计器。 (2)菜单:选择“文件|新建”命令,在“新建”对话框中选 择“查询”文件类型,然后单击“新建文件”按钮。
第4章 查询和视图
2
4.1 查询
查询和视图是检索和操作数据库的两个基本手段。
两者都可以从一个或多个相关联的数据表中提取有用的信息。 查询可以根据表或视图定义,它不依赖于数据库而独立存在, 可以显示但不能更新由查询检索到的数据(查询结果是只读 的)。
视图兼有表和查询的特点,它可以更改数据源中的数据,但
例:将“学生1”表中的“学号”字段更名为“学生证编号“
ALTER TABLE 学生1 RENAME COLUMN 学号 TO 学生证编号
对“学生1”表中的“姓名”和“出生日期”字段建立主索引
ALTER TABLE 学生1 ADD PRIMARY KEY 姓名+DTOC(出生日期) TAG 姓名_生日
(3)命令:CREATE QUERY <查询文件名>
oracle查询视图sql语句
![oracle查询视图sql语句](https://img.taocdn.com/s3/m/621a4ec118e8b8f67c1cfad6195f312b3169eb96.png)
oracle查询视图sql语句Oracle数据库是非常流行的关系型数据库管理系统,它用于存储和管理大量的数据。
在使用Oracle数据库时,通常会使用SQL(结构化查询语言)进行查询。
其中一种查询方式是使用视图(view),它是建立在表之上的一种逻辑概念,它可以让用户查看部分或者全部的数据,而又不必看到数据库表的结构。
本文将介绍Oracle中查询视图的SQL语句,其中包括创建视图、更新视图、删除视图和查询视图等。
首先,让我们看看如何使用SQL语句在Oracle中创建视图。
要创建一个视图,首先要使用CREATE VIEW语句,然后在视图的定义中,必须使用SELECT语句来指定其包含的字段和表,这种方式就可以建立一个查询视图了。
例如,要创建一个名为view_emp的视图,包含表emp中name, job和sal字段,则可以使用如下SQL语句:CREATE VIEW view_emp ASSELECT name, job, salFROM emp;接下来让我们来看看如何使用SQL语句在Oracle中更新视图。
要更新一个视图,可以使用ALTER VIEW语句,这种语句允许用户更新视图中的查询语句而不更改其基础表,同时也可以更改视图的名称以及它所参照的表。
例如,要更新view_emp的查询语句,以包含表emp中的name和sal字段,则可以使用如下SQL语句:ALTER VIEW view_emp ASSELECT name, salFROM emp;删除视图也是一个典型的SQL操作,在Oracle中可以使用DROP VIEW语句来删除一个已存在的视图。
例如,要删除view_emp视图,可以使用如下SQL语句:DROP VIEW view_emp;最后,让我们来看看Oracle中查询视图的操作使用SELECT语句查询视图。
要查询一个视图,首先要使用SELECT语句,然后指定查询的视图,其语法形式如下:SELECT * FROM view_nameWHERE conditions;其中view_name是视图的名称,conditions是查询条件,可以使用SQL的各种运算符、表达式和函数设置查询条件。
数据库的查询和视图
![数据库的查询和视图](https://img.taocdn.com/s3/m/c266548e84868762caaed523.png)
6
数据库查询
表达式比较 【例】查询XS数据库CP表中库存量在500以上的产品情况。
SELECT * FROM CP WHERE KCL !< 500
【例】查询XSCJ数据库XS表中通信工程专业总学分大于等于42的同学的情 况。
SELECT * FROM XS WHERE专业名 = ‘通信工程’ an表中不在1979年出生的学生情况。
SELECT * FROM XS WHERE 出生时间 NOT BETWEEN ‘1979-1-1’ and ‘1979-12-31’ 使用IN关键字可以指定一个值表,值表中列出所有可能的值,当表达式与值表中的任一个匹配时, 即返回TRUE,否则返回FALSE。使用IN关键字指定值表的格式为: expression IN ( expression [,…n])
3
数据库查询
【例】 5。 计算列值 。
使用SELECT对列进行查询时,在结果中可以输出对列值计算后的值, 即SELECT子句可使用表达式作为结果,格式为: SELECT expression [ , expression ]
SELECT CPMC AS ‘产品名称’,产品总值 = JG * KCL FROM CP
17
模式匹配 LIKE谓词表达式的格式为:
string_expression [ NOT ] LIKE string_expression [ ESCAPE ‘escape_character’ ]
【例】查询XSCJ数据库XS表中计算机系的学生情况。
SELECT * FROM XS WHERE 专业名 LIKE ‘计算机’ 使用LIKE进行模式匹配时,常使用通配符,即可进行模糊查询。
16
use northwind select productid, sum(quantity) as a from [order details] where productid<10 group by productid having sum(quantity) >=30 go *group by与聚集函数连用 与聚集函数连用 *having必须与 必须与group by 联用 必须与
sql数据库的查询和视图
![sql数据库的查询和视图](https://img.taocdn.com/s3/m/1abdb905a8114431b90dd8d5.png)
第4章数据库的查询和视图一、数据的关系运算:运算的对象和结果都是表(表达方式)包括:选择、投影、连接1.选择(selection):单目运算从行方面分割表记:σF(R)其中:F为条件表达式 R为表例:σF(XS),F为性别=‘男’Λ专业名=‘计算机’2.投影(projection):单目运算从列方向分割表记:ΠA(R)其中:A为列名列表;R为表例:Π姓名,专业名,总学分(XS)3.连接(join):多目运算记:R F S 其中:F为条件表达式;R、S为表①自然连接:R S,按两表的共同属性连接例:XS XS_KC? XS XS_KC KC②条件连接:R F S,两表按下条件连接例:上例中的条件F二、数据库查询使用select 语句实现表的关系运算,用符合条件的数据构成结果表语法:select <select_list>into new_table_nameform table_sourcewhere search_conditiongroup by group_by_expressionhaving search_conditionorder by order_expression [ASC/DESC] 1.选择列①选择表中的列:select列名,列名,……(*)from表名where 条件②在结果表中使用文字串(增强检索结果的可读性)select‘串’,列名,‘串’,列名,……from表名where条件③改变结果列标题(结果表更个性化,可读性强)select列名AS新列标,列名AS 新列标,……(或新列标=列名,新列标=列名,……)from表名where条件④结果表数据替换(使检索结果更能反映出有用信息)select新列标=case when条件1 then‘串’(表达式)when条件2 then‘串’(表达式)……else表达式endfrom 表名where 条件⑤结果表中显示列计算值select表达式,表达式,……from表名⑥消除结果集中的重复行select distinct列名,列名……⑦限制结果集返回行数select top n 列名,列名……2、选择行(用where条件过滤)(紧在from之后)①表达式比较:(比较运算符)比较的表达式之一或两个为NULL时,返回unknown,否则返回true/false②模式匹配:(like谓词)[谓词:返回逻辑值的运算符、关键字]字符串表达式1 [not] like字符串表达式2 [escape‘不匹配字符’](可以使用通配符进行匹配)匹配通配符:%:任意一串字符例:select * from xs where 姓名 like‘王%’_:任意一个字符例:select * from xs where 姓名 like‘王_’[]:指定范围,如[a-z]、[0-9]、[abcde]……[^]:指定不属于范围,如[^a-z]、[^0-9]、[^abcde]③范围比较:表达式[not] between 表达式1 AND表达式2注:表达式1<=表达式2,包括表达式1和2表达式IN(表达式1,表达式2,……,表达式N)④空值比较表达式is [not] NULL⑤contains 谓词:在表中指定字符串的搜索(精确、模糊、加权匹配)contains(列/*,‘匹配串’)注:先为要操作的表建立全文索引(第六章Create Index,企业管理器)⑥freetext 谓词:与contains相似,不如contains精确freetext(列/*,‘匹配串’)⑦子查询:用另一个查询结果做为where条件的一部分,可嵌套★ IN:判断某个值是否在子查询结果中,只能返回一列数据。
vfp的查询和视图
![vfp的查询和视图](https://img.taocdn.com/s3/m/f1264764bdd126fff705cc1755270722192e59be.png)
二、视图的创建和使用
视图的概念:把分散在相关表中的数据通过联 接条件把他们收集到一起,构成一张“虚表”。 这张“虚表”就是视图,视图是数据库的一个组 成部分,是基于表的并且可更新的数据集合
视图与查询的区别:视图除了可以用来查询数 据之外,还可以当作表来使用,可以作为数据源, 也可对查询出来的数据进行修改并送回源表中
❖多表查询的创建:步骤 例题 ▪ 若有2张以上的表,在添加时一定要注意先后次 序,“纽带表”要放在两张“父表”之间 ▪ 若已进行了永久性关系的设置,则无须进行联接 ▪ 修改联接条件可在“查询设计器”—“联接”卡 片中进行 ▪ 联接条件和筛选条件类似,都是选出符合条件的 记录;不同的是筛选是将字段值和筛选值进行比 较,而联接条件是将一张表中的字段值与另外一 张表中的字段值进行比较
❖查询时会考到的最难的程度如下例:
查询信息管理系中所有成绩在480分以上,并且各门课程的成
绩不低于70分的学生。要求在查询的结果中包含学号,姓名, 总分,均分,最低分,并按照总分从高到底排列
❖ 一部分查询的练习 1. 查询学生的学号,姓名,系名,总分和平均分, 按照系名升序排序,同一个系的学生按照总分 降序排序。 2. 查询每个系每门课程的总分和平均分,要求输 出课程名,课程代号,系名,每个系的平均成 绩和总成绩,按课程代号升序排序 3. 查询各个系每位教师的课时数,要求输出系名, 工号,姓名,课时数,并按系名升序排序,同 一个系的教师按照工号升序排序 4. 查询计算机科学系各位教师的课时数,要求输 出工号,姓名,系名,课时数,并按工号降序 排序,并且将查询信息保存为表,表名为:
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
第二章数据的查询的视图
实验指导书
实验目标:
查询语句的编写和视图的创建。
第一部分练习指导(50分钟)
联系1:测试ROWID和ROWNUM伪列
问题:
用户表没有建立主键约束而插入了重复的记录,为了解决数据冗余问题,必须删除表中的重复记录,用户应用程序之、只关心查询结果集中的一部分,需要限制查询返回的行数。
分析:
Oracle 的RowID伪列可以唯一地标识表中的一行,可以利用ROWID删除表中重复的记录。
ROWNUM伪列返回查询结果集中行的序号,可以通过ROWNUM限制查询返回的行数。
解决方案:
(1)启动 SQL *Plus,并登录到数据库。
(3)测试ROWID伪列。
可以看到每个行的ROWID值都是不同的。
现在删除第三行。
在次执行查询语句,就可以看到第三条记录已经被删除。
由此可见,即使不定义主键,Oracle也可以唯一区分表中的行,因为ROWID可以当作表的主键。
(4)测试ROWNUM伪列。
上述命令返回两条记录。
可以看出,使用ROWNUM 伪列可以实现类似SQL SERVER 中的TOP N功能。
练习2:使用select语句创建表
问题:
假如scott用户下的表emp要做比较大的调整。
Select语句可以与其它表中的重要的记录做一个副本。
分析:
Select 语句可检索存储在数据库中的数据。
Select 语句还可以与其它的DDL 和DML语句一起使用来执行各种操作,如创建表、插入记录和指定列的别名等。
解决方案:
(1)创建表emp表的副本,但不包含表中的记录。
(2)使用select 语句选择记录并插入到另一个表中。
练习3: 使用子查询
问题
编写sql语句,查询出工资比blake高的员工的信息。
解决方案
(1)先查询出blake的工资。
(2)利用where条件筛选出比blake的工资高的员工的信息。
(3)在sql提示符下输入一下命令,查看结果。
select * from emp where sal > (select sal from emp where ename='BLAKE');
第二部分练习(50分钟)
1.使用上一次练习中创建的三个表,查询出所有数学考试成绩都在60分以上的学生的名字和所在班级。
分析:
(1)在成绩表中查询出数学成绩在60分以上的学生。
(2)利用where语句在学生信息表中筛选出这些学上的信息。
2.利用学生信息表创建一个视图,只显示学生的姓名和年龄。
3.创建一个视图,显示学生的姓名和平均成绩,并按照分数升序排列。
提示:使用 A VG 函数和 ORDER BY 子句.
4. 编写语句以显示vendor_master表中vencode,venname 和venadd列,如果veradd列问空,则该语句显示venadd1,否则显示veradd2.
提示:使用NVL2函数
第三部分作业
1.按照第二部分练习1的要求创建一个视图。
2.编写一个sql语句,查询出所有平均分数在70和80分之间的学生信息。
3.编写一个sql语句,查询出某一个班所有课程的平均分数。
编写语句以显示order_master表中的订单的orderno,同时要显示系统日期与该订单的del_date的月份数差值,将该值四舍五入显示月份数。