SqlServer2012——Select,分组,排序、插入
1、select 简单语句
--select语句
select *
--select子句 select * AS result
--select子句,可以将结果保存在result中
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ select * From table_name
--查询table_name所有信息 select name From table_name
--查询table_name表中name select name as 学生姓名 From table_name
--查询table_name表中name且列名字以“学生姓名”显示 select name,Gender,Address From table_name
--查询table_name的姓名,性别,地址
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ select distinct name From table_name
--查询table_name的姓名且去除重复信息(此例时去除重复name)
2、设置查询条件
select * From table_name where name='张三'
精确查询 select * From table_name where name='张三' AND Gender='女'
精确查询 需要同时满足name='张三' 和 Gender='女' select * From table_name where name='张三' OR Gender='女'
精确查询 满足name='张三' 和 Gender='女'任一条件就可 select * From table_name where Age> and Age<=
精确查询 满足任一条件就可
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ select * From table_name where Address like '河南%'
精确查询 %为通配符,like用于模糊查询,此语句满足以河南开头的住址
select * From 成绩查询 where 考试编号='' AND (分数 between 90 and 95)
--查询考试编号为0802且 分数位于90~95之间的分数 select * From 成绩查询 where 考试编号='' AND (分数 % 5=0)
--查询考试编号为0802且 分数除以5的余数为0(求余是0) ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
select * From 成绩查询 where 考试编号='' AND 分数 in (85,86,87,90)
--查询考试编号为0802且 分数是85(86或87或90) select * From 成绩查询 where 考试编号='' AND 分数 not in (85,86,87,90)
--查询考试编号为0802且 分数不是85、86、87、90
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
3、排序
select * From table_name where 考试编号=‘’
order by 分数
-->查询考试编号为0801的成绩,按分数默认(升序)排序 select * From table_name where 考试编号=‘’
order by 分数 ASC
-->查询考试编号为0801的成绩,按分数 升序 排序 select * From table_name where 考试编号=‘’
order by 分数 DESC
-->查询考试编号为0801的成绩,按分数默认 降序 排序 select * From table_name where 考试编号=‘’
order by 分数 DESC,学生编号 ASC(可不写)
-->查询考试编号为0801的成绩,按分数默认 降序 排序,(成绩相同的)学生编号按 升序 排序
4、使用函数
select * From 成绩查询 where 考试编号='' AND 课程编号=''
--查询考试编号='' AND 课程编号=''的成绩查询表 select Max(分数) From 成绩查询 where 考试编号='' AND 课程编号=''
--查询考试编号='' AND 课程编号=''的成绩查询表的最高分数 select Min(分数) From 成绩查询 where 考试编号='' AND 课程编号=''
--查询考试编号='' AND 课程编号=''的成绩查询表的最低分数 select AVG(分数) From 成绩查询 where 考试编号='' AND 课程编号=''
--查询考试编号='' AND 课程编号=''的成绩查询表的平均分数 select SUM(分数) From 成绩查询 where 考试编号='' AND 课程编号=''
--查询考试编号='' AND 课程编号=''的成绩查询表的求和
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ select top 分数 From 成绩查询 where 考试编号='' AND 课程编号=''
order by 分数 DESC
--top函数:查询考试编号='' AND 课程编号=''的成绩查询表的前三个数据并降序排列(前三名)
5、分组
select 课程编号,AVG(分数) From 成绩查询 where 考试编号='' Group by 课程编号
--查询考试编号为0801且以课程编号分组的平均成绩

注意分组的group的关键字rollup和cube
select 课程编号,AVG(分数) From 成绩查询 where 考试编号='' Group by rollup(课程编号)
--查询考试编号为0801且以课程编号分组的平均成绩,且最后有个总成绩的平均值 select 课程编号,AVG(分数) From 成绩查询 where 考试编号='' Group by cube(课程编号)
--查询考试编号为0801且以课程编号分组的平均成绩,且最后有个总成绩的平均值

千万注意rollup和cube的区别
select 考试编号,课程编号,AVG(分数) From 成绩查询 Group by 考试编号,课程编号
--查询考试编号,课程编号和课程编号且以此分组的平均成绩, select 考试编号,课程编号,AVG(分数) From 成绩查询 Group by rollup(考试编号,课程编号)
--查询考试编号,课程编号和课程编号且以此分组的平均成绩,且以考试编号进行汇总,后面有总汇总 select 考试编号,课程编号,AVG(分数) From 成绩查询 Group by cube(考试编号,课程编号)
--查询考试编号,课程编号和课程编号且以此分组的平均成绩,且以课程编号进行汇总,后面有总汇总

6、Having子句
select 考试编号,课程编号,AVG(分数) From 成绩查询 Group by 考试编号,课程编号
order by 考试编号
--查询考试编号,课程编号和课程编号且以此分组的平均成绩, select 考试编号,课程编号,AVG(分数) From 成绩查询 Group by 考试编号,课程编号
Having AVG(分数) >=90
order by 考试编号
--查询考试编号,课程编号和课程编号且以此分组的平均成绩,增加having条件

7、插入语句
Insert,插入数据,手动指定
Insert
Insert into table_name VALUES('xx','xxx'......)
--不写列,代表向表中全部的列都插入数据
例如:
Insert into 学生信息 VALUES('','李白',’男‘,’1999-10-21‘,'汉','河南郑州') Insert into table_name (column1,column2...) VALUES('xx','xxx'......)
Insert into 学生信息 (学号,姓名,地址) VALUES('','李白','河南郑州')
Insert......Select:向数据表中插入从其他地方获取的值
语法:
Insert table_name [column_list]
select column
From table_list
Where search_condirions 例子:
Insert 学生信息1
select * From 学生信息 或者
Insert 学生信息1
select * From 学生信息
where 地址 like ’%郑州‘
SELECT......INTO
--语法
Select <select_list>
Into new_table
From {<table_name>}
where <search_condition>
--这么做或新建一个表,把查询结果放到新表当中
--例子
select *
into #学生信息2
from 学生信息
where 性别='男'
--新建表就是不希望查询中新建实例表
7、改语句:Update
---语法
Update [top] {table_name|view_name}
Set
{column_name{expression|DEFAULT|NULL}|@variable=expression}
where {search_condition} --例子
Update 学生信息
set 姓名='杜甫'
where 学号='' Update 学生信息
set 姓名='杜甫',出生日期='2000-8-9'
where 学号=''
update中使用From子句
update 学生信息
set s_sex=b.性别,s_address=b.家庭住址
from 学生信息 a join stuudent b on a.s_name = b.姓名
whhere b.性别='女'
8、删除语句:Delect
--语法
Delete From <table_name>
where <search_condition> --例子:
delete From table_name
--或者
delete * From table_name
--删除所有行 delete From table_name
whhere 学号='2019-10010'
SqlServer2012——Select,分组,排序、插入的更多相关文章
- mysql 分组排序前n + 长表转宽表
MySQL数据库优化的八种方式(经典必看) 建表 CREATE TABLE if not EXISTS `bb` ( `id` int not null primary key auto_increm ...
- Winform中GridView分组排序实现功能
由于客户最近要扩充公司的业务,之前基于Winform+web开发混合式的系统已经不能满足他们的需求,需要从新对系统进行分区处理. 考虑到系统模块里面用到的GridView视图比较多,我就结合了DevE ...
- mysql分组排序加序号(不用存储过程,就简简单单sql语句哦)
做前端好长时间了,好久没动sql了.在追一个喜欢的女孩,做测试的,有这么个需求求助与本屌丝,机会难得,开始折腾起来,配置mysql,建库,建表.... 一 建表 CREATE TABLE `my_te ...
- 一条Sql语句分组排序并且限制显示的数据条数
如果我想得到这样一个结果集:分组排序,并且每组限定记录集的数量,用一条SQL语句能办到吗? 比如说,我想找出学生期末考试中,每科的前3名,并按成绩排序,只用一条SQL语句,该怎么写? 表[TScore ...
- SQL语句分组排序,多表关联排序
SQL语句分组排序,多表关联排序总结几种常见的方法: 案例一: 在查询结果中按人数降序排列,若人数相同,则按课程号升序排列? 分析:单个表内的多个字段排序,一般可以直接用逗号分割实现. select ...
- oracle 分组排序函数
项目开发中,我们有时会碰到需要分组排序来解决问题的情况:1.要求取出按field1分组后,并在每组中按照field2排序:2.亦或更加要求取出1中已经分组排序好的前多少行的数据 这里通过一张表的示例和 ...
- oracle中分组排序函数用法 - 转
项目开发中,我们有时会碰到需要分组排序来解决问题的情况,如:1.要求取出按field1分组后,并在每组中按照field2排序:2.亦或更加要求取出1中已经分组排序好的前多少行的数据 这里通过一张表的示 ...
- MYSQL-实现ORACLE- row_number() over(partition by ) 分组排序功能
MYSQL-实现ORACLE- row_number() over(partition by ) 分组排序功能 由于MYSQL没有提供类似ORACLE中OVER()这样丰富的分析函数. 所以在MYSQ ...
- row_number() over (partition by....order by...)用法 分组排序
row_number() over (partition by....order by...)用法 分组排序 row_number() OVER (PARTITION BY COL1 ORDER BY ...
- hive 分组排序,topN
hive 分组排序,topN 语法格式:row_number() OVER (partition by COL1 order by COL2 desc ) rankpartition by:类似hiv ...
随机推荐
- Java8新特性(一)概览
最近看了好几段Java代码和以往的风格很不一样,都有点不太适应了,后来一查原来是Java8的新特性. 为了保持对技术的敏感性(面试...),这里我们一起来学习下Java8的新特性. 如果从技术角度来看 ...
- python中if __name__ == '__main__': 的解析(转载)
当你打开一个.py文件时,经常会在代码的最下面看到if __name__ == '__main__':,现在就来介 绍一下它的作用. 模块是对象,并且所有的模块都有一个内置属性 __name__.一个 ...
- 在VS2015中增加JQuery引用及智能提示
打开VS2015,从"工具"菜单选择NuGet选项,搜索Jquery,并点击安装. 可以看到解决方案的scripts增加了对应文件的引用 在HTML文件中可以直接引用j ...
- kbmmw 5.09 发布
New stuff ========= - Added kbmMWSmartBind.pas unit with optional kbmMWSmartBindVCL.pa ...
- 同一世界服务器架构--Erlang游戏服务器
Erlang最大的优点是方便,很多基础功能都已经集成到Erlang语言中.之前用C++写服务器的时候,管理TCP连接很繁琐,需要写一大堆代码来实现.底层的框架需要写很多代码实现,这样既浪费时间 ...
- Netty 100万级高并发服务器配置
前言 每一种该语言在某些极限情况下的表现一般都不太一样,那么我常用的Java语言,在达到100万个并发连接情况下,会怎么样呢,有些好奇,更有些期盼. 这次使用经常使用的顺手的netty NIO框架(n ...
- Android Weekly Notes Issue #243
Android Weekly Issue #243 February 5th, 2017 Android Weekly Issue #243 本期内容包括: ConstraintLayout的动画; ...
- 在react里面使用jquery插件
在react里面使用jquery插件 背景: 虽然现在react,vue等框架开启了前端开发的新篇章, 但对于一些比较复杂的页面,比如想在项目里面生成 组织架构图,人员汇报关系等还是需要用到之前的 j ...
- [haoi2014]贴海报
Bytetown城市要进行市长竞选,所有的选民可以畅所欲言地对竞选市长的候选人发表言论.为了统一管理,城市委员会为选民准备了一个张贴海报的electoral墙.张贴规则如下:1.electoral墙是 ...
- Codeforces Round #394 (Div. 2) C. Dasha and Password —— 枚举
题目链接:http://codeforces.com/problemset/problem/761/C C. Dasha and Password time limit per test 2 seco ...