SQL server 变量、运算符
一.三个表的练习
表一:学生表 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 变量、运算符的更多相关文章
- SQL Server变量赋值的方法
SQL Server变量赋值我们经常会遇到,下面就为您介绍SQL Server变量赋值的两种方法,希望可以对您学习SQL Server变量赋值有所帮助. SQL Server中对已经定义的SQL Se ...
- SQL SERVER 变量的使用和样例
定义和使用局部变量:说明: 局部变量是用户可自定义的变量. 作用范围仅在程序内部. 局部变量的名称是用户自定义的,命名的局部变量名要符合SQL Server 2000标识符命名规则=>以@开 在 ...
- sql server 变量 字符串拼接
参考:SQL server中null+字符串,isnull以及把查询结果赋给一个字符变量组成另一个查询语句 1.开始定义的字符串都为null.例如:declare @sql,那么@sql就是null ...
- SQL Server 移位运算符
参考链接:http://dataeducation.com/bitmask-handling-part-4-left-shift-and-right-shift/ SQL Server 官网的连接:h ...
- 数据库开发基础-SQl Server 变量、运算符、if、while
变量: SQL语言也跟其他编程语言一样,拥有变量.分支.循环等控制语句. 在SQL语言里面把变量分为局部变量和全局变量,全局变量又称系统变量. 局部变量: 使用declare关键字给变量声明,语法非常 ...
- (4.24)sql server变量中set与select的区别
SET vs SELECT是SQL极客之间讨论的常见话题,也是最受欢迎的面试问题之一.SET用于为变量赋值,SELECT用于赋值或从变量/ table / view等中选择值. 让我们看看在不同场景中 ...
- SQL Server变量杂谈
学习SQL的过程有进步的话还是一件很美妙的事情的 在第一家公司虽然只呆了两年,但是感觉是我进步最快的两年.那时候工作和生活都挺充实的,每天都有一点点的收获和付出,其中最大的收获莫过于掌握一些核心技能. ...
- SQL server 变量if,while,存储过程
一.变量 1.if循环 2. 3.while循环 declare @ss int set @ss =2while @ss<10begin print 'Hello' set @ss=@ss+1e ...
- SQL Server 变量定义
declare @id intdeclare @name char(10) --注意:char(10)为10位,要是位数小了会让数据出错set @id=1 set @name='sssss'selec ...
随机推荐
- Android开发之设定Dialog的位置
今天自定义了一个对话框,但是弹出时默认是显示在屏幕中间.主要代码:menuDialog = new AlertDialog.Builder(this).create(); ...
- plupload使用指南(转)
转自http://www.cnblogs.com/2050/p/3913184.html 现在随着html5技术的逐渐推广和普及,再去使用以flash为上传手段的SWFUpload显然就有点过时了,毕 ...
- System Operations on AWS - Lab 2 - Configuring VPC
建立包含Public和Private子网的VPC,建立Internet Gateway,建立Public和Private子网的路由表,创建NAT和Bastion EC2实例 1. 配置你的私有虚拟云 ...
- app抓包
http://www.360doc.com/content/14/1126/11/9200790_428168701.shtml 记得下载证书 不然有些网站是抓不到的
- Bootstrap--全局CSS样式之概览
(1)HTML5文档类型 Bootstrap 使用到的某些 HTML 元素和 CSS 属性需要将页面设置为 HTML5 文档类型.在项目中的每个页面都要参照下面的格式进行设置. Code<!DO ...
- 《转载》CSS中的三种样式来源:创作人员、读者和用户代理
CSS中的样式一共有三种来源:创作人员.读者和用户代理,来源的不同会影响到样式的层叠方式,很多第一次学习CSS的朋友,对这三种来源可能会存在一些困惑,下面我写一下自己的理解,若有错误的地方还请指正. ...
- [XML] ResourceManager一个操作Resource的帮助类 (转载)
点击下载 ResourceManager.zip /// <summary> /// 类说明:Assistant /// 编 码 人:苏飞 /// 联系方式:361983679 /// 更 ...
- 对于EditText的详细用法
EditText这个控件对于每一个Android开发者来说都是再熟悉不过了,但是,为什么有的人的EditText可以表现的那么好看,而刚入学Android的程序员来讲却丑到爆.这就充分的说明对于Edi ...
- Could not parse mapping document from resource cn/spt/model/Student.hbm.xml
初始hibernate, 写第一个程序 helloworld的错误: Exception in thread "main" org.hibernate.InvalidMapping ...
- JAVA 函数式接口与c#委托对应关系(一)
C# Action委托 VS JAVA Action 接口函数 1.c#:Action 封装一个方法,该方法不具有参数并且不返回值. 构造实体类类 using System; namespace Ac ...