一.三个表的练习

表一:学生表 student
学号:code int (主键)从1开始
姓名:name varchar(50)
性别:sex char(10)
班级:banji char(10)
语文教师编号:yujiao int
数学教师编号:shujiao int
英语教师编号:yingjiao int

表二:教师表 teacher
教师编号:code int (主键) 从1001开始
负责课程:lesson char(10)(语文、数学、英语)
年龄:age int
生日:birth datetime

表三:分数表 score
学号:code int (学生学号的外键)
语文分数:yufen decimal(18,2)
数学分数:shufen decimal(18,2)
英语分数:yingfen decimal(18,2)

学生表数据:插入三个班的学生数据,每个班的相同科目的教师都是相同的
至少每个班5个人

教师表数据:语文教师,数学教师,英语教师分别三个,每一个对应一个班级

分数表数据:学号对应的语文、数学、英语成绩

use Student
go
create table students
(
code int identity(1,1) primary key,
name varchar(50),
sex char(10),
banji char(10),
yujiao int,
shujiao int,
yingjiao int
)
go
create table teacher
(
code int identity(1001,1) primary key,
name varchar(50),
lesson char(10),
age int,
birth datetime
)
go
create table score
(
code int,
yufen decimal(18,2),
shufen decimal(18,2),
yingfen decimal(18,2),
)
go
insert into teacher values('王勇','语文',40,'1976-3-15')
insert into teacher values('石原','数学',42,'1974-3-15')
insert into teacher values('刘丽萍','英语',30,'1986-3-15')
insert into teacher values('张晓华','语文',35,'1981-3-15')
insert into teacher values('李霞','数学',33,'1983-3-15')
insert into teacher values('李娜','英语',24,'1990-3-15')
insert into teacher values('陈勇','语文',41,'1975-3-15')
insert into teacher values('刘邦','数学',37,'1970-3-15')
insert into teacher values('冯云','英语',29,'1987-3-15')
go
insert into student values('张三','男','一班',1001,1002,1003)
insert into student values('李丽','女','一班',1001,1002,1003)
insert into student values('陈龙','男','一班',1001,1002,1003)
insert into student values('邓超','男','一班',1001,1002,1003)
insert into student values('郑九','男','一班',1001,1002,1003)
insert into student values('李四','女','二班',1004,1005,1006)
insert into student values('钱枫','男','二班',1004,1005,1006)
insert into student values('李娜','女','二班',1004,1005,1006)
insert into student values('赵康','男','二班',1004,1005,1006)
insert into student values('王进京','男','二班',1004,1005,1006)
insert into student values('郭晶晶','女','三班',1007,1008,1009)
insert into student values('孙茂利','男','三班',1007,1008,1009)
insert into student values('王龙','男','三班',1007,1008,1009)
insert into student values('冯巩','男','三班',1007,1008,1009)
insert into student values('郭丽丽','女','三班',1007,1008,1009)
go
insert into score values(1,78,86,70)
insert into score values(2,83,81,90)
insert into score values(3,68,76,74)
insert into score values(4,75,89,80)
insert into score values(5,89,93,88)
insert into score values(6,55,66,80)
insert into score values(7,74,86,60)
insert into score values(8,90,86,69)
insert into score values(9,65,58,76)
insert into score values(10,71,84,75)
insert into score values(11,68,76,79)
insert into score values(12,78,67,76)
insert into score values(13,80,83,77)
insert into score values(14,78,96,63)
insert into score values(15,79,84,57)
go

--查询此次语文成绩最高的学生的信息
select * from student where code =(select top 1 code from score order by yufen desc)
--查询此次数学成绩最高的学生的信息
select * from student where code =(select top 1 code from score order by shufen desc)
--查询此次英语成绩最高的学生的信息
select * from student where code =(select top 1 code from score order by yingfen desc)
--查询此次语文成绩最低的学生的信息
select * from student where code =(select top 1 code from score order by yufen )
--查询此次数学成绩最低的学生的信息
select * from student where code =(select top 1 code from score order by shufen )
--查询此次英语成绩最低的学生的信息
select * from student where code =(select top 1 code from score order by yingfen )
--查询此次语文成绩最低的学生所任课教师的信息
select * from teacher where code = (select yujiao from student where code =(select top 1 code from score order by yufen ))
--查询此次数学成绩最低的学生所任课教师的信息
select * from teacher where code = (select shujiao from student where code =(select top 1 code from score order by shufen ))
--查询此次英语成绩最低的学生所任课教师的信息
select * from teacher where code = (select yingjiao from student where code =(select top 1 code from score order by yingfen ))
--查询此次语文成绩最高的学生所任课教师的信息
select * from teacher where code = (select yujiao from student where code =(select top 1 code from score order by yufen desc))
--查询此次数学成绩最高的学生所任课教师的信息
select * from teacher where code = (select shujiao from student where code =(select top 1 code from score order by shufen desc ))
--查询此次英语成绩最高的学生所任课教师的信息
select * from teacher where code = (select yingjiao from student where code =(select top 1 code from score order by yingfen desc))
--查询学生信息,将所有语文任课教师编号改为该科目的任课教师名字显示
select code ,name ,sex,banji,(select name from teacher where code = yujiao) as 语文教师 from student
--查询学生信息,将所有任课教师编号改为该科目的任课教师名字显示
select code ,name ,sex,banji,(select name from teacher where code = yujiao) as 语文教师,
(select name from teacher where code = shujiao) as 数学教师,
(select name from teacher where code = yingjiao) as 英语教师 from student
--查询各个学生的学号,姓名,语文分数,数学分数,英语分数,以及三门课里面每一门课的任课教师姓名
select student.code ,name ,score.yufen,shufen,yingfen ,
(select name from teacher where code = yujiao) as 语文教师,
(select name from teacher where code = shujiao) as 数学教师,
(select name from teacher where code = yingjiao) as 英语教师
from student join score on student.code =score.code
--查询每个班级里的语文最高分
select banji as 班级, MAX(yufen) as 语文最高分
from student join score on student.code = score.code group by banji
--查询每个班级里的数学最高分
select banji as 班级, MAX(shufen) as 语文最高分
from student join score on student.code = score.code group by banji
--查询每个班级里的英语最高分
select banji as 班级, MAX(yingfen) as 语文最高分
from student join score on student.code = score.code group by banji
--查看每个班的语文平均分
select banji,AVG(yufen) from student join score on student.code = score.code group by banji
--查询语文课程平均分最高的班级的语文教师的信息
select * from teacher where code =
(select top 1 yujiao from student where banji =
(select top 1 banji from student join score
on student.code = score.code group by banji order by AVG(yufen) desc))
--查询数学课程平均分最高的班级的数学教师的信息
select * from teacher where code =
(select top 1 shujiao from student where banji =
(select top 1 banji from student join score
on student.code = score.code group by banji order by AVG(shufen) desc))
--查询英语课程平均分最高的班级的英语教师的信息
select * from teacher where code =
(select top 1 yingjiao from student where banji =
(select top 1 banji from student join score
on student.code = score.code group by banji order by AVG(yingfen) desc))

二.变量

1.局部变量
declare @xingming varchar(50)--声明定义一个varchar类型的叫做@xingming的变量
set @xingming = '赵匡胤'--使用set关键字时一个变量一个变量的赋值
--声明一个变量和给他设置一个值需要一起执行

--更改code值为@code的人的名字为@xingming的值
update student set name=@xingming where code =@code
use lianxi
--更改code值为@code值的人的人名为李莲英
declare @code int
set @code =17
update student set name = '李莲英' where code = @code

--在查询语句中也可以给变量进行赋值
--取code值为1 的人的姓名
declare @name varchar(50)
select @name = name from student where code =1
select @name

--在查询语句中也可以给变量进行赋值(不加条件)
--不加任何条件的情况下执行以下语句,只将最后一行的name复制给@name
declare @name varchar(50)
select @name = name from student
select @name --变量是用来临时存储一个值

2.常用全局变量      @@****
--@@connections 连接次数
print @@connections -- 打印出我自从启动sql之后进行了多少次的数据库连接
--@@error 错误
insert into score values (33,44,55,66)
print @@error --执行上一个sql语句是有没有错误,没有错误返回0
--@@language 语言
print @@language --当前使用的语言
--@@rowcount row行 count数量
print @@rowcount --返回上一次执行sql语句时在表中影响的行数
--@@version 版本
print @@version --所使用的SQL的版本信息

三.运算符

--算数运算符
-- + - * / %
--关系运算符
--> < >= <= != !> !<
--逻辑运算符
--and 两个都成立
--or 两个钟只要一个成立
--any 任意一个都得成立
--between..and.. 在...之间
--exists --存在
--in 在....里面
--like 像
--not 非
declare @jia int
set @jia =10%2
set @jia =4+3
set @jia = 10-4
PRINT @jia

--运算符的优先级
--第一级:* / %
--第二级:正好负号(+)(-)
--第三级:+ -
--第四级:> < >= <= != !> !<
--第五级:not
--第六级:and or between and
--第七级:all any in like some exists
--第八级:=(等号)

--if 语句,分支语句
--写法:
--if 表达式
--begin
-- 语句
--end
--else
--begin
-- 语句
--end
--在里面只有一句语句的时候可以省略begin end
练习:

1.给老师做评教
--及格人数超过所教人数超过6人就打印优秀,否则,打印教学质量差
--查看张晓华所教学生有多少及格的(个数)
declare @sumji int
select @sumji=COUNT(*) from score where code in
(select code from Student where yujiao =
(select top 1 code from teacher where name ='张晓华') and yufen>=60)
--判断部分
if @sumji>6
begin
print '优秀'
print '继续保持'
end
else
begin
print '教学质量差'
print '好好上课'
end

2.查看数学分数最高的学生的性别,
--若是男,[这是一个男生]
--否则,[这是一个女生]
declare @sex char(10)
select @sex= sex from Student where code=(select top 1 code from score order by shufen desc)
if @sex='男'
print '这是一个男生'
else
print'这是一个女生'

3.查出年纪最大的教师的姓名和年龄,如果超过45岁,打印,【***在干几年就退休了】
--如果小于30岁,打印【***你还年轻,继续努力】
--否则,【***正当年!!】
declare @tname varchar(50)
declare @tage int
select top 1 @tname= name ,@tage= age from teacher order by age desc
if @tage>45
print @tname+ '在干几年就退休了'
if @tage<30
print @tname+'你还年轻,继续努力'
else
print @tname+'正当年!!'

SQL server 变量、运算符的更多相关文章

  1. SQL Server变量赋值的方法

    SQL Server变量赋值我们经常会遇到,下面就为您介绍SQL Server变量赋值的两种方法,希望可以对您学习SQL Server变量赋值有所帮助. SQL Server中对已经定义的SQL Se ...

  2. SQL SERVER 变量的使用和样例

    定义和使用局部变量:说明: 局部变量是用户可自定义的变量. 作用范围仅在程序内部. 局部变量的名称是用户自定义的,命名的局部变量名要符合SQL Server 2000标识符命名规则=>以@开 在 ...

  3. sql server 变量 字符串拼接

    参考:SQL server中null+字符串,isnull以及把查询结果赋给一个字符变量组成另一个查询语句  1.开始定义的字符串都为null.例如:declare @sql,那么@sql就是null ...

  4. SQL Server 移位运算符

    参考链接:http://dataeducation.com/bitmask-handling-part-4-left-shift-and-right-shift/ SQL Server 官网的连接:h ...

  5. 数据库开发基础-SQl Server 变量、运算符、if、while

    变量: SQL语言也跟其他编程语言一样,拥有变量.分支.循环等控制语句. 在SQL语言里面把变量分为局部变量和全局变量,全局变量又称系统变量. 局部变量: 使用declare关键字给变量声明,语法非常 ...

  6. (4.24)sql server变量中set与select的区别

    SET vs SELECT是SQL极客之间讨论的常见话题,也是最受欢迎的面试问题之一.SET用于为变量赋值,SELECT用于赋值或从变量/ table / view等中选择值. 让我们看看在不同场景中 ...

  7. SQL Server变量杂谈

    学习SQL的过程有进步的话还是一件很美妙的事情的 在第一家公司虽然只呆了两年,但是感觉是我进步最快的两年.那时候工作和生活都挺充实的,每天都有一点点的收获和付出,其中最大的收获莫过于掌握一些核心技能. ...

  8. SQL server 变量if,while,存储过程

    一.变量 1.if循环 2. 3.while循环 declare @ss int set @ss =2while @ss<10begin print 'Hello' set @ss=@ss+1e ...

  9. SQL Server 变量定义

    declare @id intdeclare @name char(10) --注意:char(10)为10位,要是位数小了会让数据出错set @id=1 set @name='sssss'selec ...

随机推荐

  1. 自己封装的工具类,使用原生SwipeRefreshLayout+RecycleView实现下拉刷新和加载更多

    实现SwipeRefreshLayout+RecycleView实现刷新 在你的xml文件里写上如下代码: <android.support.v4.widget.SwipeRefreshLayo ...

  2. iOS监听电话事件

    项目上有个需求,要求打完电话后加积分. 首先导入这两个头文件: #import <CoreTelephony/CTCallCenter.h> #import <CoreTelepho ...

  3. python 验证码

    python写的验证码小程序 ##################验证码,数字+字母 import random check_code="" for i in range(6): ...

  4. js 连续赋值

    无意中网上发现的这个问题,预想的结果和真实的结果大相径庭. var a={n:1} var b=a; a.x=a={n:2} console.log(a.x); console.log(b.x); u ...

  5. webrtc学习———记录二:canvas学习

    参考资料: http://bucephalus.org/text/CanvasHandbook/CanvasHandbook.html#getcontext2d https://developer.m ...

  6. 学习java随笔第七篇:java的类与对象

    类 同一个包(同一个目录),类的创建与调用 class Man{ String name; void GetMyName() { System.out.println(name); } } publi ...

  7. 检测SqlServer服务器IO是否瓶颈

    通过性能监视器监视 Avg. Disk Queue Length   小于2 Avg. Disk sec/Read , Avg. Disk sec/Write  小于10ms 可以用数据收集器定时收集 ...

  8. Oracle 11g-R2 SQL Developer连接MSSQL2008

    操作系统环境:WINDOWS8.1 工具: Oracle 11g-R2  SQL Developer 网络资源:http://sourceforge.net/project/showfiles.php ...

  9. cas系列(一)--cas单点登录基本原理

    (这段时间打算做单点登录,因此研究了一些cas资料并作为一个系列记录下来,一来可能会帮助一些人,二来对我自己所学知识也是一个巩固.) 一.为什么要实现单点登录 随着信息化不断发展,企业的信息化过程是一 ...

  10. Linux如何查找大文件或目录总结-1127

    原帖地址:http://www.cnblogs.com/kerrycode/p/4391859.html  谢谢潇湘隐者,谢谢老大 在Linux系统中,如何去搜索一些比较大的文件呢?下面我整理了一下在 ...