SQL sever 学习,2016,5,31,(重点:100行以后,字符串操作。)
--别名和表达式
select OrderDate,YEAR(OrderDate)as 订单年份
from orders;
--选择
select OrderDate,YEAR(OrderDate)as 订单年份
from orders
where year(OrderDate)=2006;
--在分组的情况下,select字句会有限制,只能查询整个组的统计情况
select YEAR(OrderDate),count(*),SUM(OrderDate)
from orders
group by OrderDate;
select count(*),SUM(OrderDate)
from orders;
--NULL 空,与NULL运算的结果还是NULL
--必须使用特殊的方式来使用NULL
select OrderDate
from orders
where not OrderDate is null;
--组函数会忽略null
--having 筛选统计后的数据
select ... COUNT(*)
from orders
group by ...
having COUNT(*) > 2;
--order by 排序
select OrderDate,YEAR(OrderDate)as 订单年份
from orders
order by OrderDate desc;
--top 查询前几条
select top(2)--查询前2条
--SQL
select CityName as 城市
from city
select *
from distributors
select top(3) *
from items
-- select SQL语句本身不区分大小写
--百分比
select top(20) percent *
from distributors
--with ties 表示额外附加于最后一条记录相等的记录
select top(5)with ties BossName
from distributors
order by BossName
--over子句 称为开窗函数
select BossName
from distributors;
select count(*)
from distributors ;
--over
select BossName ,count(*) over()as 人总数
from distributors
select Item, OrderNum ,TotalPrice
,sum(TotalPrice ) over() as 总价
,sum(TotalPrice) over(partition by Item)--partition by 相当于做一个相等的选择,选出等于的值
from items
--排名
--row_number行号
--rank 排名,表示前面有多少
--dense_rank密集排名
--ntile 分组
select row_number() over(order by CityCode)as 行号
,rank() over(order by CityCode)as 排名
,dense_rank() over(order by CityCode)as 密集排名
,ntile(3) over(order by CityCode)as 分组
,BossName,CityCode
from distributors
--排名结合部分
select
ROW_NUMBER() over(order by CityCode),
ROW_NUMBER() over(partition by CityCode order by CityCode),--组里边再排名
CityCode ,BossName
from distributors
select *
from distributors
--where 条件
select *
from distributors
where DistriNum >=1004 and DistriNum <=1010
--between and,包含边界,注意上界和和下界
select *
from distributors
where DistriNum between 1004 and 1010
--in
select *
from distributors
where DistriNum =1004 or DistriNum =1009 or DistriNum =1010
select *
from distributors
where DistriNum in (1004,1009,1010)
--like必须掌握,字符串匹配, % 任意多个字符, _ 任意一个字符。
select *
from distributors
where BossName like '王%'
select *
from distributors
where BossName like '_为%'
select *
from distributors
where BossName like '%真%真%'
--case 简单表达式,比较是否相等
select BossName ,CityCode ,
case CityCode
when 'CY' then '谁外'
else '其他'
end
from distributors
--case 搜索表达式
select BossName ,CityCode ,
case
when CityCode in('CY','PG') then 'wwww'
when CityCode is null then '未知'
when BossName ='王为' then '就是他'
else '去其他区'
end
as hhe
from distributors
--*************************************************************
--SQL字符数据类型
--char 类型 一个长度的字符串
--char(8) 8个长度的字符串 固定长度的字符串
--varchar(8) 可变长度字符串 最长占8个 多余的自动退回
--nchar 国际化编码,unicode,字符长度,每个字符占2个字节,固定长度
--nvarchar(8) 可变长度的国际化字符串************************
--nvarchar(4000) 4000最大值,8000字节
--nvarchar(max) varchar(max) 特别长度
--**************************************************************
--定义变量
declare @s varchar(10);
set @s ='hello';
print @s;
set @s=@s+'world';
print @s;
--isnull函数
declare @s varchar(10);
print @s;
set @s= isnull(@s,' ') + 'world';
print @s;
--注意:在SQL中 下标是从1开始的
--substring(BossName,3,4)截取字符串
--left 表示截取左边 left(BOssName,4)
--right表示截取右边 right(BossName,4)
declare @s varchar(10);
set @s ='hello';
print @s;
set @s=@s+'world';
print @s;
print len(@s); -- 实际长度
print datalength(@s);-- 索取的长度
--模板在前,源字符串在后,,**出现在字符串中的位置,从高1开始
declare @s varchar(10);
set @s='helloworld';
print @s;
select @s ,charindex('w',@s)--找到位置
select @s,substring(@s,charindex('w',@s)+1,10)
--replace替换
declare @s varchar(20)
set @s='hello world';
print @s;
select @s,replace(@s,'hello','你好啊')
--stuff 替换
declare @s varchar(20)
set @s='hello world'
print @s
select @s,stuff(@s,charindex(' ',@s),1,':')
--upper变大写,lower变小写
--rtrim() 去掉右边,lteim()去掉左边
--ltrim(rtrim()) 去掉左右边的所有字符
declare @s varchar(20)
set @s=' hello wor ld '
print @s;
set @s=rtrim(@s);
print @s;
set @s=ltrim(@s);
print @s;
set @s=ltrim(rtrim('o'));
print @s;
SQL sever 学习,2016,5,31,(重点:100行以后,字符串操作。)的更多相关文章
- SQL Sever 学习系列之二
SQL Sever 学习系列之二 SQL Server 学习系列之一(薪酬方案+基础) 四.有关时间输出问题 select GETDATE() 日期时间 ----显示为:2013-07 ...
- SQL Sever 学习系列之一
SQL Sever 学习系列之一 本学习系列,从实际工作需要中积累,对于一个新手而言,写出几条漂亮的查询语句,应该是可以受启发的. 一.问题的需求是:员工薪酬发放,现有资金能发放多少人,哪些人应得? ...
- SQL Sever 学习系列之三
SQL Sever 学习系列之三 SQL Server 学习系列之一(薪酬方案+基础) SQL Server 学习系列之二(日期格式问题) 五.经理今天刚谈到with的用法(with的 ...
- tail -f 实时查看日志文件 linux查看日志后100行
tail -f 实时查看日志文件 tail -f 日志文件logtail - 100f 实时查看日志文件 后一百行tail -f -n 100 catalina.out linux查看日志后100行搜 ...
- 3-1创建Sql Sever数据库登录名
登录名:连接Sql Sever 服务器 数据库用户名: Sql Sever 的使用者 每个用来登录Sql Sever 的账户都是一个用户. 同一个数据库可以拥有多个用户,每一个用户也同时可以访问多个数 ...
- java连接到sql sever 2008_java基础学习
(sql sever 2008跟sql sever 2005装载JDBC驱动的方法是一样的) 一.加载驱动的文字教程 1.准备相关的软件(Eclipse除外,开源软件可以从官网下载) <1> ...
- SQL数据库学习,常用语句查询大全
数据库学习 sql server数据库基本概念 使用文件保存数据存在几个缺点: 1.文件的安全性问题: 2.文件不利于查询和对数据的管理: 3.文件不利于存放海量数据 4.文件在程序中控制不方便. 数 ...
- SQL 基础学习(2) Joining 和function , 作业没有做,需要看百宝箱。NOsql的概念
SQL 基础学习(2) Joining 可以同时关联(joining)多张表进行复杂的查询. 相比于用Rails捞出数据再用Ruby进行过滤组合,使用SQL更加高效,节能. 以下是 users has ...
- SQL语句学习手册实例版
SQL语句学习手册实例版 表操作 例1 对于表的教学管理数据库中的表 STUDENTS ,可以定义如下: CREATE TABLE STUDENTS (SNO NUMERIC (6, ...
随机推荐
- 无法删除对象 '产品',因为该对象正由一个 FOREIGN KEY 约束引用。
在删除northwindcs表时,发生报错,消息 3726,级别 16,状态 1,第 2 行,无法删除对象 '产品',因为该对象正由一个 FOREIGN KEY 约束引用.此时判断是因为有其他表的外键 ...
- 自定义UI集成微信、QQ、微博分享功能
目前社会化分享是一个非常常见的功能,通过阅读官方文档可以进行对应平台的分享.在项目中原本有微信的分享,后来需要集成QQ和微博的分享,于是想着用ShareSDK,在使用的过程中发现ShareSDK中的w ...
- 百度app测试服务
https://cloud.baidu.com/product/mat.html?t=cp:ct|pp:fcforbce242jrcs|cn:fcforbce242|pu:newAATJRKWS002 ...
- 【java项目小记--JManager】项目开始原因及github部署
--记于2016-8-11 毕业已三载,忽然想起大学时的毕业设计项目,想到曾在毕业答辩上说,会吸取老师点评并逐渐完善该项目.而今 老师点评已忘了个干净,项目也还是毕业时的样子,正好最近有些时间,打算兑 ...
- roundabout插件使用(3d旋转轮播图)兼容IE8
<!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8&quo ...
- js通过继承实现私有函数
本文是原创文章,如需转载,请注明文章出处 主要思想就是在继承时,只开放共有的属性和方法,不开放另外某些函数,从而实现私有的作用. function A(){ this.x = 100; this.y ...
- (46) odoo核心文档分享
*前言: 要掌握一个系统,还得有扎实的基础,最好的方法,阅读核心文档 然后去实践. *核心文档列表如下: odoo8官方参考.pdf 链接: http://p ...
- boost.asio与boost.log同时使用导致socket不能正常收发数据
现象: 1. 没有使用boost.log前能正常收发数据 2.加入boost.log后async_connect没有回调 fix过程: 1. gdb调试发现程序block在pthread_timed_ ...
- SSL/TLS协议运行机制的概述
互联网的通信安全,建立在SSL/TLS协议之上. 本文简要介绍SSL/TLS协议的运行机制.文章的重点是设计思想和运行过程,不涉及具体的实现细节.如果想了解这方面的内容,请参阅RFC文档. 一.作用 ...
- java.lang.NumberFormatException: For input string: "1608020001 " 错误
错误: java.lang.NumberFormatException: For input string: "1608020001 " at java.lang.Numbe ...