20141104--SQL,查询习题,约束

--创建学生信息表:学号,姓名,班级,性别,语文教师,数学教师,英语教师
--创建一个教师表:编号,姓名,课程,性别,出生日期
--创建一个分数表:语文,数学,外语,学号
--查询 语文成绩最高的学生信息
--查询 数学成绩最低的任课教师信息
--查询汇总表,有分数,学生姓名,班级,及任课教师姓名。
--查询每个班里数学最高分
--查询语文课程平均分最高的班级的任课教师信息
create database shujuku02
go
use shujuku02
go
create table jiaoshi--创建jiaoshi表--
(
    code int primary key,--code 列设置主键
    name varchar(20),
    kecheng varchar(20),
    sex varchar(10),
    riqi varchar(20),
)
go
create table xuesheng--创建xuesheng表,与jiaoshi表有关联
(
    xuehao int primary key,--xuehao列设置主键
    name varchar(20),
    banji varchar(10),
    sex varchar(10),
    Cnjs int references [dbo].[jiaoshi]([code]),--设置外键,与jiaoshi关联
    Majs int references [dbo].[jiaoshi]([code]),--
    Enjs int references [dbo].[jiaoshi]([code]),--
)
go
create table fenshu--创建fenshu表,与学生表有关联
(
    xuhao int references [dbo].[xuesheng]([xuehao]),--设置外键,与xuesheng关联
    yuwen decimal(10,2),
    shuxue decimal(10,2),
    yingyu decimal(10,2),
)
go
insert into jiaoshi values (1,‘刘欣欣‘,‘语文‘,‘女‘,‘1980-5-10‘)
insert into jiaoshi values (2,‘文祥‘,‘语文‘,‘女‘,‘1983-9-19‘)
insert into jiaoshi values (3,‘毕华‘,‘数学‘,‘男‘,‘1977-1-10‘)
insert into jiaoshi values (4,‘闻广华‘,‘数学‘,‘男‘,‘1979-5-10‘)
insert into jiaoshi values (5,‘张峰‘,‘英语‘,‘男‘,‘1984-5-10‘)
insert into jiaoshi values (6,‘李莉‘,‘英语‘,‘女‘,‘1986-7-7‘)
select *from jiaoshi
insert into xuesheng values (1,‘曹操‘,‘1班‘,‘男‘,1,3,5)
insert into xuesheng values (2,‘曹丕‘,‘1班‘,‘男‘,1,3,5)
insert into xuesheng values (3,‘司马懿‘,‘1班‘,‘男‘,1,3,5)
insert into xuesheng values (4,‘大乔‘,‘1班‘,‘女‘,1,3,5)
insert into xuesheng values (5,‘小乔‘,‘1班‘,‘女‘,1,3,5)

insert into xuesheng values (6,‘张飞‘,‘2班‘,‘男‘,2,3,6)
insert into xuesheng values (7,‘关羽‘,‘2班‘,‘男‘,2,3,6)
insert into xuesheng values (8,‘刘备‘,‘2班‘,‘男‘,2,3,6)
insert into xuesheng values (9,‘诸葛‘,‘2班‘,‘男‘,2,3,6)
insert into xuesheng values (10,‘貂蝉‘,‘2班‘,‘女‘,2,3,6)

insert into xuesheng values (11,‘袁绍‘,‘3班‘,‘男‘,1,4,5)
insert into xuesheng values (12,‘袁术‘,‘3班‘,‘男‘,1,4,5)
insert into xuesheng values (13,‘马超‘,‘3班‘,‘男‘,1,4,5)
insert into xuesheng values (14,‘华容‘,‘3班‘,‘女‘,1,4,5)
insert into xuesheng values (15,‘马术‘,‘3班‘,‘男‘,1,4,5)
select *from xuesheng
insert into fenshu values (1,80,80,58)
insert into fenshu values (2,65,35,80)
insert into fenshu values (3,78,42,80)
insert into fenshu values (4,85,80,15)
insert into fenshu values (5,80,87,80)
insert into fenshu values (6,86,80,76)
insert into fenshu values (7,28,82,80)
insert into fenshu values (8,45,72,68)
insert into fenshu values (9,99,99,10)
insert into fenshu values (10,87,88,36)
insert into fenshu values (11,80,25,82)
insert into fenshu values (12,68,28,80)
insert into fenshu values (13,59,78,79)
insert into fenshu values (14,28,99,96)
insert into fenshu values (15,99,18,77)
select *from fenshu
--------------------
select *from jiaoshi
select *from xuesheng
select *from fenshu 

-----------查询 语文成绩最高的学生信息
select *from xuesheng where xuehao in(--根据xuehao查询学生信息
select xuhao from fenshu where yuwen=(--根据yuwen分数查询学生xuhao
select MAX(yuwen) from fenshu
))
-----------查询 数学成绩最低的任课教师信息
select *from jiaoshi where code in (--根据教师code查询教师信息
select Majs from xuesheng where xuehao in(--根据学生的xuehao查询任课教师
select xuhao from fenshu where shuxue=(--查询shuxue分数的学生学号
select MIN(shuxue) from fenshu --查询shuxue最低分
)))
----------查询汇总表,有分数,学生姓名,班级,及任课教师姓名。
select xuesheng.name,banji,yuwen,shuxue,yingyu,
(select name from jiaoshi where xuesheng.Cnjs=jiaoshi.code)语文教师,--根据教师code查询教师姓名
(select name from jiaoshi where xuesheng.Majs=jiaoshi.code)数学教师,
(select name from jiaoshi where xuesheng.Enjs=jiaoshi.code)英语教师
from xuesheng join fenshu on xuesheng.xuehao=fenshu.xuhao
----------查询每个班里数学最高分
--首先根据学号对应出两个表的关系,使得班级与分数连接起来
select banji,shuxue from xuesheng join fenshu on xuesheng.xuehao=fenshu.xuhao
--然后加入条件
select banji,max(shuxue) as 数学最高分 from xuesheng join fenshu on xuesheng.xuehao=fenshu.xuhao group by banji
--------另一种方法
select max(shuxue),banji from
(select shuxue,(select banji from xuesheng where xuesheng.xuehao=fenshu.xuhao)as banji from fenshu) as newtable
group by banji

----------查询语文课程的平均分最高的班级的任课教师的信息

select *from jiaoshi where code=(--根据编号查询教师信息
select top 1 Cnjs from xuesheng join fenshu on xuesheng.xuehao=fenshu.xuhao group by banji,Cnjs order by AVG(yuwen) desc--按班级分组语文平均成绩的最高分的教师编号
)
-------------约束------------
drop table yueshu
create table yueshu
(
    xuehao int primary key,--xuehao列设置主键
    name varchar(20),
    age int,
    sex varchar(10),
    cid varchar(50) unique--创建表时加入唯一键约束
)
go
create table yueshu01
(
    xuehao int primary key,--xuehao列设置主键
    name varchar(20),
    age int,
    sex varchar(10),
    cid varchar(50)
)
--已创建好表,再加入唯一键约束:(注意表的数据中不可有重复)
create unique index index_123--给约束命名
on yueshu01(cid)
insert into yueshu values (1,‘张三‘,35,‘男‘,0010)
insert into yueshu values (2,‘张四‘,36,‘男‘,0010)
select *from yueshu

CHECK约束

唯一键 约束:

时间: 2024-10-09 03:37:37

20141104--SQL,查询习题,约束的相关文章

SQL查询习题 20140909

create database mydb go use mydb create table student ( --学号 sno varchar(3) not null primary key, --姓名 sname varchar(4) not null, --性别 ssex varchar(2) not null, --出生年月 sbirthday datetime, --所在班级 class varchar(5) ) create table teacher ( --教工编号 tno va

oracle常用经典SQL查询

1 常用SQL查询: 2 3 1.查看表空间的名称及大小 4 5 select t.tablespace_name, round(sum(bytes/(1024*1024)),0) ts_size 6 from dba_tablespaces t, dba_data_files d 7 where t.tablespace_name = d.tablespace_name 8 group by t.tablespace_name; 9 10 2.查看表空间物理文件的名称及大小 11 12 sel

ORACLE 常用SQL查询

一.ORACLE的启动和关闭 1 .在单机环境下 要想启动或关闭ORACLE系统必须首先切换到ORACLE用户,如下 su  -  oracle a.启动ORACLE系统 oracle > svrmgrl SVRMGR > connect internal SVRMGR > startup SVRMGR > quit b.关闭ORACLE系统 oracle > svrmgrl SVRMGR > connect internal SVRMGR > shutdown

SQL查询数据库是否存在

在实际工作中会遇到通过SQL查询数据库是否存在的情况,下面一些语句可以提供一些帮助,本文的语句是在SQL08R2中测试的 1,查询当前数据库服务器所有数据库 select *  From master.dbo.sysdatabases 2,查询数据库是否存在 select count(*) From master.dbo.sysdatabases where name='数据库名' 3,查询某数据库中所有用户表 select * from sysobjects where xtype='U' ‘

SQL基础--> 约束(CONSTRAINT)

--============================= --SQL基础--> 约束(CONSTRAINT) --============================= 一.几类数据完整性 实体完整性:表中记录不反复(不论什么两条记录不全等)而且每条记录都有一个非空主键 域完整性:表中字段值必须与字段数据类型.格式.有效范围相吻合 參照完整性:不能引用不存在的值 自己定义完整性:依据特定业务领域定义的需求完整性 保证数据完整性的几种经常用法 约束(最经常使用) 过程 函数 触发器 实体

SQL 查询性能优化----解决书签查找

先来看看什么是书签查找: 当优化器所选择的非聚簇索引只包含查询请求的一部分字段时,就需要一个查找(lookup)来检索其他字段来满足请求.对一个有聚簇索引的表来说是一个键查找(key lookup),对一个堆表来说是一个RID查找(RID lookup).这种查找即是——书签查找. 书签查找根据索引的行定位器从表中读取数据.因此,除了索引页面的逻辑读取外,还需要数据页面的逻辑读取. 从索引的行定位器到从表中读取数据这之间会产生一些额外的开销,本文就来解决这个开销. 先看下我的测试表结构: 其中可

SQL查询速度慢的原因

1.没有索引或者没有用到索引(这是查询慢最常见的问题,是程序设计的缺陷) 2.I/O吞吐量小,形成了瓶颈效应. 3.没有创建计算列导致查询不优化. 4.内存不足 5.网络速度慢 6.查询出的数据量过大(可以采用多次查询,其他的方法降低数据量) 7.锁或者死锁(这也是查询慢最常见的问题,是程序设计的缺陷) 8.sp_lock,sp_who,活动的用户查看,原因是读写竞争资源. 9.返回了不必要的行和列 10.查询语句不好,没有优化 ●可以通过如下方法来优化查询 : 1)把数据.日志.索引放到不同的

sql中表级约束和列级约束

sql中表级约束和列级约束,在SQL SERVER中, (1) 对于基本表的约束分为列约束和表约束约束是限制用户输入到表中的数据的值的范围,一般分为列级约束与表级约束.列级约束有六种:主键Primary key.外键foreign key .唯一 unique.检查 checck .默认default .非空/空值 not null/ null表级约束有四种:主键.外键.唯一.检查 列约束是对某一个特定列的约束,包含在列定义中,直接跟在该列的其他定义之后,用空格分隔,不必指定列名:表约束与列定义

sql查询未走索引问题分析之查询数据量过大

前因: 客户咨询,有一个业务sql(代表经常被执行且重要),全表扫描在系统占用资源很高(通过ash报告查询得到信息) 思路: 1.找到sql_text,sql_id 2.查看执行计划 3.查询sql涉及对象的对象数据量,段大小,行数量,where条件列,是否存在索引,列的选择读情况如何 4.总结,优化整改 1.找到sql_text,sql_id 094cmrxrahdy2 SELECT 8~10个列名称(由于设计用户信息,因此部分信息不再详细说明) FROM Prescription WHERE

Spring Data JPA原生SQL查询

package com.wanda.cms.dao.repository;import org.springframework.stereotype.Repository;import javax.persistence.EntityManager;import javax.persistence.PersistenceContext;import javax.persistence.Query;import java.math.BigInteger;import java.util.*; /*