技术好文:SQL查询语句基本练习

简介: 技术好文:SQL查询语句基本练习

一、简单查询


1、列出全部学生的信息。


SELECT FROM 学生


2、列出软件专业全部学生的学号及姓名。


SELECT 学号,姓名 FROM 学生 WHERE专业="软件"


3、列出所有必修课的课号。


SELECT DISTINCT 课号 FROM 必修课


4、求1号课成绩大于80分的学生的学号及成绩,并按成绩由高到低//代码效果参考:http://www.lyjsj.net.cn/wz/art_23853.html

列出。

SELECT 学号,成绩 FROM 选课 WHERE 课号="1" AND成绩>80 ORDER BY 成绩 DESC


5、列出非软件专业学生的名单。


方法一:SELECT 姓名 FROM 学生 WHERE专业"软件"


方法二:SELECT 姓名 FROM 学生 WHERE NOT专业="软件"


方法三:SELECT 姓名 FROM 学生 WHERE专业!="软件"


6、查询成绩在70~80分之间的学生选课得分情况


方法一:SELECT FROM 选课 WHERE成绩>=70 AND 成绩<=80


方法二:SELECT FROM 选课 WHERE 成绩 BETWEEN 70AND 80


不在此范围内的查询:(注意写出和以下语句等价的语句)


SELECT FROM 选课 WHERE 成绩 NOT BETWEEN 70AND 80


7、列出选修1号课或3号课的全体学生的学号和成绩。


方法一:SELECT 学号,成绩 FROM 选课 WHERE 课号="1" OR课号="3"


方法二:SELECT 学号,成绩 FROM 选课 WHERE 课号 IN("1","3")


相反条件查询:SELECT 学号,成绩 FROM 选课 WHERE 课号 NOTIN ("1","3")


8、列出所有98级学生的学生成绩情况。


SELECT FROM 选课 WHERE 学号 LIKE"98%"


SELECT FROM 选课 WHERE 学号 LIKE "98 __//代码效果参考:http://www.lyjsj.net.cn/wx/art_23851.html

"

相反条件查询:SELECT FROM 选课 WHERE 学号 NOT LIKE"98%"


9、列出成绩为空值(或不为空值)的学生的学号和课号。


答案一:SELECT 学号,课号 FROM 选课 WHERE 成绩 ISNULL


答案二:SELECT 学号,课号 FROM 选课 WHERE 成绩 IS NOTNULL


10、求出所有学生的总成绩。


SELECT SUM(成绩) AS 总成绩 FROM 选课


11、列出每个学生的平均成绩。


SELECT 学号,AVG(成绩) AS 平均成绩 FROM 选课 GROUP BY学号


12、列出各科的平均成绩、最高成绩、最低成绩和选课人数。


SELECT 课号,AVG(成绩) AS 平均成绩,MAX(成绩) AS最高分,;


MIN(成绩) AS 最低分,COUNT(学号) AS 选课人数 FROM 选课GROUP BY 课号


二、连接查询


(一)简单连接


1、列出选修1号课的学生姓名及成绩。


SELECT 姓名,成绩 FROM 学生,选课 WHERE 学生.学号=选课.学号AND 课号="1"


2、列出选修1号课的学生的学号、姓名及成绩。


SELECT 学生.学号,姓名,成绩 FROM 学生 S,选课 X WHERES.学号=X.学号 AND 课号="1"


3、求出总分大于150的学生的学号、姓名及总成绩。


SELECT 学生.学号,姓名,SUM(成绩) AS 总成绩 FROM学生,选课;


WHERE 学生.学号=选课.学号 GROUP BY 选课.学号 HAVINGSUM(成绩)>150


(二)自连接查询


1、列出那些专业相同的学生相应的姓名及专业信息。


SELECT a.姓名,b.姓名,专业 FROM 学生 a,学生 b WHEREa.学号b.学号 AND a.专业=b.专业


2、求至少选修1号课和2号课的学生的学号。


SELECT X.学号 FROM 选课 X,选课 Y WHERE X.学号=Y.学号AND X.课号="1" AND Y.课号="2"


3、有以下表rate.dbf


币种1代码 C(2)、币种2代码 C(2)、买入价 N(8,4)、卖出价 N(8,4)


外汇汇率.dbf


币种1 C(4)、币种2 C(4)、买入价 N(8,4)、卖出价 N(8,4)


外汇代码.dbf


外汇名称 C(10)、外汇代码 C(10)


要求:将所有“外汇汇率”表中的数据插入rate表中并且顺序不变,由于“外汇汇率”中的币种1和币种2存放的是外币名称,而rate表中的币种1代码和币种2代码应该存放外币代码,所以插入时要做相应的改动,外币名称与外向代码的对应关系存储在“外汇代码”表中。


SELECT A.外币代码 AS 币种1代码,B.外币代码 AS币种2代码,;


买入价,卖出价 FROM 外汇代码 A,外汇汇率,外汇代码B;


WHERE A.外币名称=外汇汇率.币种1 AND B.外币名称=外汇汇率.币种2INTO TABLE rate


4、假定有“雇员”表(雇员号 C(2),雇员姓名 C(6),经理号C(2)),根据雇员关系列出上一级经理及其所领导的职员清单。(教案中的例题)


SELECT "领导",S.雇员姓名,"雇员",E.雇员姓名 FROM 雇员S,雇员 E WHERE S.雇员号=E.经理


(三)超连接


1、列出选修1号课的学生姓名及成绩。


方法一:(使用简单连接查询格式)


SELECT 姓名,成绩 FROM 学生,选课 WHERE 学生.学号=选课.学号AND 课号="1"


方法二:(使用内部连接格式)


SELECT 姓名,成绩 FROM 学生 INNER JOIN 选课 ON学生.学号=选课.学号 WHERE 课号="1"


方法三:内部连接的INNER短语可以省略。(与方法二等价)


SELECT 姓名,成绩 FROM 学生 JOIN 选课 ON学生.学号=选课.学号 WHERE 课号="1"


2、查询订货管理数据库中数据的仓库号、城市、供应商名和地址信息。


方法一:使用简单连接格式。


SELECT 仓库.仓库号,城市,供应商名,地址 FROM供应商,订购单,职工,仓库;


WHERE 供应商.供应商号=订购单.供应商号 AND订购单.职工号=职工.职工号;


AND 职工.仓库号=仓库.仓库号


方法二:使用超连接的内部连接格式。(注意连接条件的顺序)


SELECT 仓库.仓库号,城市,供应商名,地址 FROM 供应商 JOIN 订购单JOIN 职工 JOIN 仓库 ;


ON 职工.仓库号=仓库.仓库号 ON 订购单.职工号=职工.职工号 ON供应商.供应商号=订购单.供应商号


3、查询没有选修任何课程的学生姓名。


方法一:使用嵌套查询


SELECT 姓名 FROM 学生 WHERE 学号 NOT IN (SELECT学号 FROM 选课)


方法二:使用超连接的右连接。


SELECT 姓名 FROM 选课 RIGHT JOIN 学生 ON选课.学号=学生.学号 WHERE选课.学号学生.学号


方法三:使用超连接的左连接。(注意表名顺序和方法二的不同)


SELECT 姓名 FROM 学生 LEFT JOIN 选课 ON选课.学号=学生.学号 WHERE选课.学号学生.学号


三、嵌套查询


(一)普通嵌套与谓词EXISTS


1、列出选修汇编语言课的学生的学号。


方法一:


SELECT 学号 FROM 选课 WHERE 课号=(SELECT 课号 FROM课程 WHERE 课名="汇编语言")


方法二:使用谓词EXISTS。注意和方法一格式上的不同。


SELECT 学号 FROM 选课 WHERE EXIST (SELECT FROM 课程 ;


WHERE 课名="汇编语言" AND选课.课号=课程.课号)


2、求软件专业所有必修课的课程信息。


方法一:


SELECT FROM 课程 WHERE 课号 IN; (SELECT 课号FROM 必修课 WHERE 必修专业="软件")


方法二:


SELECT FROM 课程 WHERE EXIST (SELECT FROM 必修课 WHERE 必修专业="软件" ;


AND 课程.课号=必修课.课号)


(二)量词ANY、SOME、ALL


1、求选修2号课的学生中,成绩比选修1号课的最低成绩要高的学生的学号和成绩。


方法一:


SELECT 学号,成绩 FROM 选课 WHERE 课号="2" AND成绩>;


(SELECT MIN(成绩) FROM 选课 WHERE课号="1")


方法二:ANY等价于SOME,所以可将ANY换成SOME。


SELECT 学号,成绩 FROM 选课 WHERE 课号="2" AND成绩>ANY ;


(SELECT 成绩 FROM 选课 WHERE课号="1")


2、求选修2号课的学生中,成绩比选修1号课的任何学生的成绩都要高的那些学生的学号和成绩。


方法一:


SELECT 学号,成绩 FROM 选课 WHERE 课号="2" AND成绩>;


(SELECT MAX(成绩) FROM 选课 WHERE课号="1")


方法二:


SELECT 学号,成绩 FROM 选课 WHERE 课号="2" AND成绩>ALL ;


(SELECT 成绩 FROM 选课 WHERE课号="1")


(三)内外层互相关嵌套(外层依赖于内层的查询结果,内层依赖于外层来进一步查询)


1、列出每门课程中成绩最高的选课信息。


SELECT FROM 选课 A WHERE 成绩=(SELECTMAX(成绩) FROM 选课 B WHERE A.课号=B.课号)


2、列出每个学生中成绩低于本人平均成绩的选课信息。


SELECT FROM 选课 A WHERE成绩<(SELECT AVG(成绩) FROM 选课 B WHEREA.学号=B.学号)


3、列出表“订购单2.dbf”(其内容就是在订购单表的基础上增加一个总金额字段)中每个职工经手的具有最高总金额的订购单信息。(教案中例题)


SELECTout.职工号,out.供应商号,out.订货单号,out.订货日期,out.总金额;


FROM 订购单 out WHERE 总金额=(SELECT MAX(总金额)FROM 订购单 inner1;


Where out.职工号=inner1.职工号)


四、操作功能


1、在课程表中插入新的元组(5,大学英语)。


INSERT INTO 课程(课号,课名)VALUES("5","大学英语")


2、给学生表中男生的记录加上删除标记。


DELETE FROM 学生 WHERE 性别="男"


3、将选课表中所有课程的成绩分别提高5分。将课号为“4”的课程的成绩置为空值。


UPDATE 选课 SET 成绩=成绩+5


UPDATE 选课 SET 成绩=NULL WHERE课号="4"


五、定义表结构


1、建立研究生表,该表不属于任何数据库,其结构如表所示:


字段名


字段类型


字段长度


小数位数


特殊要求


学号


C


6


姓名


C


8


性别


C


2


年龄


N


3


0


入学年月


D


允许空值


CREATE TABLE 研究生 FREE (学号 C(6),姓名 C(8),性别C(2),年龄 N(3,0),入学年月 D NULL)


2、假设已经建立了XSK数据库,在XSK中建立“学生1”表,其结构如表所示


字段名


字段类型


字段长度


小数位数


特殊要求


学号


C


6


主索引


姓名


C


8


不能为空


性别


C


2


年龄


N


3


0


年龄大于10小于45


是否党员


L


入学年月


D


默认值为1999年9月1日


OPEN DATABASE XSK


CREATE TABLE 学生1 (学号 C(6) PRIMARY KEY,姓名C(8) NOT NULL,性别 C(2),;


年龄 N(3,0) CHECK 年龄>10 AND年龄<45 ERROR "年龄必须大于10小于45",是否党员 L,;


入学年月 D DEFAULT {^1999-9-1})


3、在XSK数据库建立“课程1”表,其结构如表所示:


字段名


字段类型


字段长度


小数位数


特殊要求


课号


C


4


主索引


课程名


C


10


不能为空


学分


N


2


CREATE TABLE 课程1 (课号 C(4) PRIMARY KEY,课程名C(10) NOT NULL,学分 N(2))


4、在XSK数据库建立“选课1”表,其结构如表所示:


字段名


字段类型


字段长度


小数位数


特殊要求


学号


C


6


外索引与学生表建立关系


课号


C


4


外索引与课程表建立关系


成绩


N


5


2


CREATE TABLE 选课1 (学号 C(6) REFERENCE 学生,课号C(4) REFERENCE 课程,成绩 N(5,2))


六、修改表结构


1、为“课程1”表添加一个开课学期字段,字段类型为数值型,长度为1。


ALTER TABLE 课程1 ADD COLUMN 开课学期N(1)


2、修改开课学期字段为字符型,合法值为1或2。


ALTER TABLE 课程1 ALTER COLUMN 开课学期 C(1)CHECK 开课学期="1" OR 开课学期="2"


3、删除“课程1”表中对开课学期字段的合法值约束,设置默认值为1。


ALTER TABLE 课程1 ALTER 开课学期 DROPCHECK


ALTER TABLE 课程1 ALTER 开课学期 SET DEFAULT"1"


4、删除“课程1”表中的开课学期字段。修改课程名字段为“课名”字段。


ALTER TABLE 课程1 DROP 开课学期 RENAME 课程名 TO课名


5、在“学生1”表的“年龄”字段上建立候选索引。


ALTER TABLE 学生1 ADD UNIQUE 年龄 TAG年龄


6、在“学生1”表中添加一个出生日期字段,删除年龄字段。


ALTER TABLE 学生1 ADD 出生日期 D


ALTER TABLE 学生1 DROP UNIQUE TAG 年龄 DROP年龄


七、补充练习


利用订货管理数据库中表数据,用SQL完成查询。


1、检索在北京的供应商的名称。


SELECT 供应商名 FROM 供应商 WHERE地址="北京"


2、检索出向供应商S3发过订购单的职工的职工号和仓库号。


方法一(嵌套查询):


SELECT 职工号,仓库号 FROM 职工 WHERE 职工号IN;


(SELECT 职工号 FROM 订购单 WHERE供应商号="S3")


方法二(连接查询):


SELECT 职工.职工号,仓库号 FROM 职工,订购单 ;


WHERE 职工.职工号=订购单.职工号 AND供应商号="S3"


3、检索出和职工E1、E3都有联系的北京的供应商信息。


SELECT FROM 供应商 WHERE 地址="北京" AND 供应商号IN;


(SELECT 供应商号 FROM 订购单 WHERE 职工号="E1") AND供应商号 IN;


(SELECT 供应商号 FROM 订购单 WHERE职工号="E3")


4、检索出向S4供应商发出订购单的仓库所在的城市。


SELECT 城市 FROM 仓库,职工,订购单 WHERE仓库.仓库号=职工.仓库号 ;


AND 职工.职工号=订购单.职工号 AND供应商号="S4"


5、检索出由工资多于1230元的职工向北京的供应商发出的订购单号。


SELECT 订货单号 FROM 职工,订购单,供应商 WHERE职工.职工号=订购单.职工号;


AND 订购单.供应商号=供应商.供应商号 AND工资>1230 AND 地址="北京"


6、检索出所有仓库的平均面积。


SELECT AVG(面积) AS 面积 FROM 仓库


7、检索出每个仓库中工资多于1220元的职工个数。


SELECT 仓库号,COUNT() 职工个数 FROM职工WHERE工资>1220 GROUP BY 仓库号


8、检索工资低于本仓库平均工资的职工信息。


SELECT FROM 职工 AA WHERE工资<(SELECT AVG(工资) FROM 职工 BB WHEREAA.仓库号=BB.仓库号)

相关文章
|
14天前
|
SQL 存储 缓存
高基数 GroupBy 在 SLS SQL 中的查询加速
本文详细介绍了SLS中的高基数GroupBy查询加速技术。
|
13天前
|
SQL 运维 程序员
一个功能丰富的SQL审核查询平台
一个功能丰富的SQL审核查询平台
|
7天前
|
SQL 机器学习/深度学习 自然语言处理
Text-to-SQL技术演进 - 阿里云OpenSearch-SQL在BIRD榜单夺冠方法剖析
本文主要介绍了阿里云OpenSearch在Text-to-SQL任务中的最新进展和技术细节。
|
17天前
|
SQL 安全 数据库
基于SQL Server事务日志的数据库恢复技术及实战代码详解
基于事务日志的数据库恢复技术是SQL Server中一个非常强大的功能,它能够帮助数据库管理员在数据丢失或损坏的情况下,有效地恢复数据。通过定期备份数据库和事务日志,并在需要时按照正确的步骤恢复,可以最大限度地减少数据丢失的风险。需要注意的是,恢复数据是一个需要谨慎操作的过程,建议在执行恢复操作之前,详细了解相关的操作步骤和注意事项,以确保数据的安全和完整。
36 0
|
20天前
|
SQL 数据库 Java
HQL vs SQL:谁将统治数据库查询的未来?揭秘Hibernate的神秘力量!
【8月更文挑战第31天】Hibernate查询语言(HQL)是一种面向对象的查询语言,它模仿了SQL的语法,但操作对象为持久化类及其属性,而非数据库表和列。HQL具有类型安全、易于维护等优点,支持面向对象的高级特性,内置大量函数,可灵活处理查询结果。下面通过示例对比HQL与SQL,展示HQL在实际应用中的优势。例如,HQL查询“从员工表中筛选年龄大于30岁的员工”只需简单地表示为 `FROM Employee e WHERE e.age &gt; 30`,而在SQL中则需明确指定表名和列名。此外,HQL在处理关联查询时也更为直观易懂。然而,对于某些复杂的数据库操作,SQL仍有其独特优势。
26 0
|
20天前
|
SQL 关系型数据库 MySQL
|
20天前
|
API Java 数据库连接
从平凡到卓越:Hibernate Criteria API 让你的数据库查询瞬间高大上,彻底告别复杂SQL!
【8月更文挑战第31天】构建复杂查询是数据库应用开发中的常见需求。Hibernate 的 Criteria API 以其强大和灵活的特点,允许开发者以面向对象的方式构建查询逻辑,同时具备 SQL 的表达力。本文将介绍 Criteria API 的基本用法并通过示例展示其实际应用。此 API 通过 API 构建查询条件而非直接编写查询语句,提高了代码的可读性和安全性。无论是简单的条件过滤还是复杂的分页和连接查询,Criteria API 均能胜任,有助于提升开发效率和应用的健壮性。
37 0
|
20天前
|
Java UED 开发者
当错误遇上Struts 2:一场优雅的异常处理盛宴,如何让错误信息成为用户体验的救星?
【8月更文挑战第31天】在Web应用开发中,异常处理对确保用户体验和系统稳定性至关重要。Struts 2 提供了完善的异常处理机制,包括 `exception` 拦截器、`ActionSupport` 类以及 OGNL 表达式,帮助开发者优雅地捕获和展示错误信息。本文详细介绍了 Struts 2 的异常处理策略,涵盖拦截器配置、错误信息展示及自定义全局异常处理器的实现方法,使应用程序更加健壮和用户友好。
30 0
|
20天前
|
Java XML Maven
跨越时代的飞跃:Struts 2 升级秘籍——从旧版本无缝迁移到最新版,焕发应用新生!
【8月更文挑战第31天】随着软件技术的发展,Struts 2 框架也在不断更新。本文通过具体案例指导开发者如何从旧版平滑升级到 Struts 2.6.x。首先更新 `pom.xml` 中的依赖版本,并执行 `mvn clean install`。接着检查 `struts.xml` 配置,确保符合新版本要求,调整包扫描器等设置。审查 Action 类及其注解,检查配置文件中的弃用项及插件。更新自定义拦截器实现,并验证日志配置。最后,通过一系列测试确保升级后的系统正常运行。通过这些步骤,可以顺利完成 Struts 2 的版本升级,提升应用的安全性和性能。
57 0
|
20天前
|
测试技术 Java
揭秘Struts 2测试的秘密:如何打造无懈可击的Web应用?
【8月更文挑战第31天】在软件开发中,确保代码质量的关键在于全面测试。对于基于Struts 2框架的应用,结合单元测试与集成测试是一种有效的策略。单元测试聚焦于独立组件的功能验证,如Action类的执行逻辑;而集成测试则关注组件间的交互,确保框架各部分协同工作。使用JUnit进行单元测试,可通过简单示例验证Action类的返回值;利用Struts 2 Testing插件进行集成测试,则可模拟HTTP请求,确保Action方法正确处理请求并返回预期结果。这种结合测试的方法不仅提高了代码质量和可靠性,还保证了系统各部分按需协作。
9 0