`
reallyafei
  • 浏览: 98832 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

sql语句优化

阅读更多

有如下三个表
1.查询出没有选择大学物理课程的所有学生
2.查询出超过3个人选择的所有课程

student 表

 

SNO NAME
1 张三
2 李四
3 王五
4 黄七
5 刘八


course 表

 

CNO NAME
001 大学物理
002 大学英语
003 C语言
004 高等数学


course_select 表

 

SNO CNO
1 001
1 002
1 003
2 001
2 003
3 002
3 003
4 001
4 004
5 001
5 002



我写的sql语句如下
1. select s.sno, max(s.name) from course_select t, course c, student s
    where t.cno=c.cno and t.sno=s.sno group by s.sno
    having count(case when c.name ='大学物理' then s.sno end) = 0

 

    --或者

    select s.sno,s.name from student s where s.sno not in (
    select distinct cs.sno from course c,course_select cs 
    where c.cno=cs.cno and c.name='大学物理')

 
2. select t.cno, t.name from (
    select c.cno, c.name,count(c.cno) n from course c, course_select cs
    where c.cno = cs.cno group by c.cno, c.name) t where n>3

 

    --或者(抛兄给出的,我想应该是最优化的了。)

    select t.cno, max(c.name) from course c, course_select t
    where c.cno = t.cno group by t.cno having count(t.cno) > 3


各位大虾看看,我写得对不对啊,还有没有更好的写法啊,还请不吝赐教!

 

分享到:
评论
4 楼 抛出异常的爱 2009-05-27  
是不等啊....没看清题
用case 语句 行变列....
3 楼 reallyafei 2009-05-27  
抛出异常的爱 写道
select a.name
from a , b ,c
where 1=1
and a.sno = c.sno
and b.cno = c. cno
and b.name = #name#

这个不符合啊,我要查出的是不包含的啊
抛出异常的爱 写道
select max(b.name)
from b, c
where 1=1
and b.cno = c.cno
group by c.cno
haveing count(c.sno)>3

恩,这个不错,我已经加上去了,谢谢抛兄指点!
2 楼 抛出异常的爱 2009-05-27  
select a.name
from a , b ,c
where 1=1
and a.sno = c.sno
and b.cno = c. cno
and b.name = #name#

select max(b.name)
from b, c
where 1=1
and b.cno = c.cno
group by c.cno
haveing count(c.sno)>3
1 楼 reallyafei 2009-05-26  
晕,怎么没有更好的写法吗

相关推荐

    新一代智能SQL语句优化技术

    新一代智能SQL语句优化技术是数据库管理领域的重要进步,它主要针对的是提升数据库应用程序的性能。SQL(结构化查询语言)作为访问和更新数据的主要工具,其性能优化对于整体系统效率有着重大影响。通常,SQL语句...

    非常好用的SQL语句优化34条+sql语句基础

    在SQL编程领域,掌握高效的SQL语句优化技巧和基础知识是至关重要的。以下是对"非常好用的SQL语句优化34条+sql语句基础"这一主题的详细解析: 1. **索引优化**:索引是提高查询速度的关键。创建合适的索引(主键、...

    sql语句优化原则

    SQL语句优化原则是数据库管理和应用开发中的关键环节,它涉及到如何提高查询效率,减少资源消耗,提升系统整体性能。以下是一些针对SQL语句优化的重要原则和方法: 1. **利用索引**:索引是提高查询速度的关键。...

    sql语句优化之降龙十八掌

    在数据库管理中,SQL语句优化是提升系统性能的关键步骤,尤其对于大型系统而言,一个高效的SQL查询可以显著减少响应时间,改善用户体验。本文将详细阐述"sql语句优化之降龙十八掌",逐一解析这十八个优化技巧,帮助...

    SQL语句优化手册

    ### SQL语句优化手册 #### 一、引言 随着信息技术的发展,数据库系统在各行业中扮演着越来越重要的角色。为了确保数据库系统能够高效地运行,SQL语句优化成为了提升系统性能的关键因素之一。SQL(Structured Query...

    sql语句优化建议

    ### SQL语句优化建议 #### 重要性与挑战 SQL语句优化是数据库管理与维护中的关键环节,尤其在处理大规模数据集时显得至关重要。优化不仅能够显著提升查询效率,减少资源消耗,还能改善用户体验,确保系统的稳定性...

    Sql语句优化(很好的资料)

    SQL语句优化是提高软件系统效率的关键技术,尤其是在大数据量的场景下,高效的SQL能够显著提升数据库查询速度,降低系统资源消耗。以下是一些关于SQL优化的重要知识点: 1. **IN操作符**: - 使用IN操作符虽然使得...

    sql语句优化心得

    ### SQL语句优化心得 #### 引言 在软件开发过程中,SQL语句的编写往往直接关系到应用程序的性能表现。特别是在系统初期阶段,由于数据量较小,即使编写了一些效率较低的SQL语句,也可能不会立即暴露出来。然而,...

    SQL语句优化,语法优化

    SQL语句优化是数据库性能提升的关键环节,尤其是在大数据量的环境下。优化SQL语句能够显著提高查询速度,减少服务器负载,提升系统整体效率。以下是一些关于SQL语句优化的重要知识点: 1. **选择最有效的表名顺序**...

    必须掌握的30种SQL语句优化

    便于Java入门人员交流学习。可以深刻理解该语言的常用API。帮助初学者尽快入门。

    SQL语句优化规则

    SQL语句优化是数据库管理中的关键环节,尤其是在大型企业级应用中,高效的SQL查询能够显著提升系统的整体性能。本文将详细探讨几个重要的SQL优化规则,这些规则主要针对Oracle数据库系统。 1. **选用适合的ORACLE...

    SQL Server数据库sql 语句优化

    sql 语句优化 SQL Server数据库查询速度慢的原因有很多

    SQL语句优化

    优化数据库、SQL语句优化的原则、不要以为只有SELECT语句是查询。实际上,带有任何WHERE条件的 DML(INSERT、UPDATE、DELETE)语句中都包含查询要求,在后面的文章中,当说到查询时,不一定只是指SELECT语句,也有可能...

    一般SQL语句优化整理

    ### 一般SQL语句优化整理 #### 概述 在数据库操作中,SQL查询语句是数据检索的核心,其性能直接影响到应用系统的响应时间和资源消耗。对于一般的SQL语句优化,不仅能够提升查询效率,还能改善用户体验。本文将对...

    JAVA-SQL语句优化.doc

    总之,SQL语句优化是提升数据库性能的关键。了解并遵循上述原则,可以编写出更加高效的SQL,从而提高系统整体的响应速度和可用性。在实际开发中,应不断学习和实践,以适应不同场景下的性能需求。

    sql语句优化技术分析

    SQL语句优化是数据库管理中的核心技能之一,它关乎到系统的性能、响应时间和资源利用率。在处理大量数据时,有效的SQL优化策略能显著提升数据库应用的效率。以下是对SQL语句优化技术的详细分析: 一、理解执行计划 ...

    SQL语句优化技术分析

    标题和描述均提到了“SQL语句优化技术分析”,这一主题是数据库管理和性能提升的关键领域。在数据库系统中,SQL(Structured Query Language)是用于管理关系数据库的标准语言,其优化对于提高查询效率、减少资源...

Global site tag (gtag.js) - Google Analytics