一.三个表的练习

表一:学生表 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. git 删除配置的远程地址

    删除(origin 名称需根据你本地查询出来的想删除的名字, 查询命令为 git remote -v) git remote rm origin 添加(origin 名称可根据需要添加) git re ...

  2. SDWebImage 源码阅读分享

    SDWebImage 源码阅读分享 疑问列表 SDWebImage 整体框架图,主要的类包含哪些 SDWebImage 如何进行缓存管理,过期失效策略,缓存更新 SDWebImage 如何多线程处理的 ...

  3. 简洁JS 日历控件 支持日期和月份选择

    原文出处 以下这个JS日历控件是我的闲暇之余自己编写的,所有的代码全部在IE7/IE8/Firefox下面测试通过, 而且可以解决被iframe层遮盖的问题.现在只提供两种风格(简洁版和古典版)和两种 ...

  4. C#语法糖之第六篇: 泛型委托- Predicate<T>、Func<T>

    今天继续分享泛型委托的Predicate<T>,上篇文章讲了Action委托,这个比Action委托功不一样的地方就是委托引用方法是Bool返回值的方法,Action为无返回值.首先我们看 ...

  5. 在解决方案中添加Layout,Image文件夹

    在解决方案中添加文件夹如Layout,Image,可以使用映射的方式(右键该解决方案,添加对Layout的映射),这样IIS的地址和该文件夹就绑定了:拖该文件夹中的 文件时,显示的就是该文件在IIS中 ...

  6. 一个操作Sql2005数据库的类(备份,还原,分离,附加,添加删除用户等操作)(转载)

    /* * 更新时间 :2011-09-01 16:06 * 更 新 人 :苏飞 */ using System; using System.Collections.Generic; using Sys ...

  7. JS控制文字一个一个出现

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  8. PHP 单一入口

    单一入口概述 单一入口的应用程序就是说用一个文件处理所有的HTTP请求,例如不管是列表页还是文章页,都是从浏览器访问index.php文件,这个文件就是这个应用程序的单一入口. 打个比方,大家都要上W ...

  9. 24种设计模式--迭代模式【Iterator Pattern】

    周五下午,我正在看技术网站,第六感官发觉有人在身后,扭头一看,我 C,老大站在背后,赶忙站起来,“王经理,你找我?” 我说. “哦,在看技术呀.有个事情找你谈一下,你到我办公室来一下.” 老大说. 到 ...

  10. [学习笔记]设计模式之Decorator

    写在前面 为方便读者,本文已添加至索引: 设计模式 学习笔记索引 Decorator(装饰)模式,可以动态地给一个对象添加一些额外的职能.为了更好地理解这个模式,我们将时间线拉回Bridge模式笔记的 ...