---------------------- <a href="http://edu.csdn.net"target="blank">ASP.Net+Android+IOS开发</a>、<a href="http://edu.csdn.net"target="blank">.Net培训</a>、期待与您交流! ----------------------

29 数字函数

Abs() :绝对值

Ceiling():舍入到最大整数  3.33à4  -3.6à-3    (天花板)

Floor():舍入到最小整数    2.89à2   -3.6à-4    (地板)

Round():四舍五入    select round(-3.61,0)à -4

Len():字符串长度    select Len(FName) from T_Employee

Lower(),Upper() 大小写转换

LTrim(),RTrim() 去除左右空格

Substring(string,startindex,length)           截取字符串
              select substring(FName,2,2) from T_Employee

GetDate()获取当前时间
DateAdd(datepart,number,date) 计算增加后的日期  datepart:yyyy年份 mm月份,dy 当年度的第几天 ,dd 日   ,hh小时

Select DateAdd(day,3,getDate())  --当前日期上加3天

DateDiff(datedepart,startDate,endDate) –计算两时间的差额

Select Datediff(hh,getDate(),DateAdd(day,-3,getDate()))  --计算出当前时间与(当前时间-3天)之间的小时数

Select FName,FInDate,DateDiff(year,FInDate,getDate())from T_Employee  --员工入职年数

Select datediff(year,FIndate,getDate()),count(*) from T_Employee group by datediff(year,FIndate,getDate())  --每年入职人数

DatePart(datepart,date)  取时间的某一部分

select datePart(year,getDate())  --取出当前时间年份

Select datePart(year,FIndate),count(*) from T_Employee group by  datePart(year,FIndate)       --每年入职人数

30类型转换函数

Cast( express as data_type):  select cast(‘2’as int)

Convert(data_type , express):   select  convert(int,’22’)

31流控函数

Isnull()  select isnull(FName,N’佚名’)from T_Employee  --如果name有为null,则显示佚名

Case  表达式 when 值 then 返回值
when 值 then 返回值
else  返回值  end

Select FName,(case Flevel when 1 then ‘VIP’ when 2 then  N‘普通客户’ when 3 then N’特殊客户’else ‘无’end ) as 客户类型 from T_Customer    --case用法1

Select FName,(case when FSalary<2000 then N‘低收入’when FSalary>=2000 and FSalary<=3000 then N‘中等收入’else N’高收入’end) as 收入情况 from T_Employee   --case用法2

Select (case when a>b then a else b end),(case when c>d then c else d end ) from T  --最大值

Select FNumber,(case when FAmount>0 then FAmount else 0 end)as 收入,(case when FAmount<0 then abs(FAmount) else 0 end)as 支出 from T_Employee

Select Name,Sum( case Scores when N‘胜’then 1 else  0 end  )as 胜,Sum(case scores when N’负’ then 1 else 0 end)as 负 from T_Scores group bu Name      --统计个球员的胜负情况

32 练习:
create table T_CallRecord(id int not null,CallerNumber nvarchar(10),TelNum nvarchar(20),StartDateTime datetime,EndDateTime datetime,primary key(id))

insert into T_CallRecord values('001','02030004304','2008-09-20','2008-10-21')

insert into T_CallRecord values('001','02030004304','2008-07-20','2008-09-21')

insert into T_CallRecord values('002','2030004304','2008-09-20','2008-09-21')

insert into T_CallRecord values('001','02030004304','2008-01-20','2008-05-21')

insert into T_CallRecord values('003','2030004304','2008-06-20','2008-07-21')

insert into T_CallRecord values('001','02030004304','2008-09-20','2008-09-21')

insert into T_CallRecord values('004','02030004304','2008-08-20','2008-09-21')

insert into T_CallRecord values('001','2030004304','2008-09-20','2008-10-21')

insert into T_CallRecord values('005','02030004304','2008-04-20','2008-05-21')

truncate table T_CallRecord

select top 5 * from T_CallRecord order by DATEDIFF(SECOND,StartDateTime,EndDateTime) desc --通话时间最长的top5条记录

select SUM(DateDiff(SECOND,StartDateTime,EndDateTime)) as 长途电话时间

from T_CallRecord where TelNum like '0%' --长途电话总时长

select top 3 CallerNumber

from T_CallRecord

where DATEDIFF(MM,GETDATE(),StartDateTime)=0

group by CallerNumber

order by sum(DATEDIFF(SECOND,StartDateTime,EndDateTime)) desc

--本月通话时间最长的前名人员编号

select top 3 CallerNumber,COUNT(*) as 次数

from T_CallRecord where DATEDIFF(MM,GETDATE(),StartDateTime)=0 group by CallerNumber order by count(*) desc

--本月拨打电话次数最多的前三个呼叫员的编号

select CallerNumber,TelNum,DATEDIFF(SECOND,StartDateTime,EndDateTime)as 总时长 from T_CallRecord union all

select N'汇总',sum((case  when TelNum like '0%' then DATEDIFF(second,StartDateTime,EndDateTime)   else 0 end  ))as 长途电话总时长 ,

sum((case when TelNum not like '0%' then DATEDIFF(second,StartDateTime,EndDateTime)else 0 end ))as 市内电话总时长

from T_CallRecord --汇总

33 索引(目录):在要建索引的字段上声明下要为这个字段添加索引,提高查询效率,对经常要查询的字段加上索引。

优缺点:查询效率高,更新操作速度慢,占用空间,所以只在经常检索的字段添加索引

34 join用法:

Select o.billId,c.name,c.age  from T_customer  as c join T_order as o on c.id=o.cusId -–客户表和订单表的关联

Select o.billId,c.name,c.age  from T_customer  as c join T_order as o on c.id=o.cusId where c.age>15  --年龄大于15

Select o.billId,c.name,c.age  from T_customer  as c join T_order as o on c.id=o.cusId where c.age>(select avg(age) from T_customer)--年龄大于平均年龄

35 子查询

Select * from (select * from T_customer) as table1

单值子查询:select 1 as a1 ,(select Count(*)from T_customer) as a2

Select * from T_Reader where FYearofJoin in(2001,2003)—入会时间在01,03年的读者信息

Select * from T_Reader where FYearOfJoin in(select Fyearpublished from T_Book   ) –入会时间在书出版的时间的读者信息

select * from (

select ROW_NUMBER()over(order by callerNumber desc)as newRow, CallerNumber,TelNum

from T_CallRecord) as newtable where newtable.newRow>3 and newtable.newRow<5 –row_number用法,子查询用法

------------<a href="http://edu.csdn.net"target="blank">ASP.Net+Android+IOS开发</a>、<a href="http://edu.csdn.net"target="blank">.Net培训</a>、期待与您交流! ---------------
详细请查看:<a href="http://edu.csdn.net" target="blank">http://edu.csdn.net</a>

黑马程序员+SQL基础(下)的更多相关文章

  1. 黑马程序员+SQL基础(上)

    黑马程序员+SQL基础 ---------------<a href="http://edu.csdn.net"target="blank">ASP ...

  2. 黑马程序员+Winform基础(下)

    ---------------<a href="http://edu.csdn.net"target="blank">ASP.Net+Android ...

  3. 黑马程序员+Winform基础(上)

    黑马程序员+Winform基础 ---------------<a href="http://edu.csdn.net"target="blank"> ...

  4. 黑马程序员Java基础班+就业班课程笔记全发布(持续更新)

    正在黑马学习,整理了一些课程知识点和比较重要的内容分享给大家,也是给自己拓宽一些视野,仅供大家交流学习,大家有什么更好的内容可以发给我 ,现有黑马教程2000G  QQ 1481135711 这是我总 ...

  5. 黑马程序员_Java基础:网络编程总结

    ------- android培训.java培训.期待与您交流! ---------- Java语言是在网络环境下诞生的,它是第一个完全融入网络的语言,虽然不能说它是对支持网络编程做得最好的语言,但是 ...

  6. 黑马程序员----java基础笔记中(毕向东)

    <p>------<a href="http://www.itheima.com" target="blank">Java培训.Andr ...

  7. 黑马程序员_Java基础组成

    Java语言基础组成 2.1关键字 main不是关键字,但被JVM所识别的名称. 关键字的定义和特点 定义:被Java语言赋予了特殊含义的单词. 特点:关键字中所有字母都为小写. 用于定义数据类型的关 ...

  8. sql数据黑马程序员——SQL入门

    最近研究sql数据,稍微总结一下,以后继续补充: ---------------------- ASP.Net+Android+IO开辟S..Net培训.等待与您交流! --------------- ...

  9. 函数sql黑马程序员——SQL常用函数

    最近使用开辟的过程中出现了一个小问题,顺便记录一下原因和方法--函数sql ---------------------- ASP.Net+Android+IO开辟S..Net培训.等待与您交流! -- ...

随机推荐

  1. [刘阳Java]_MyBatis_映射文件的常用标签总结_第5讲

    MyBatis中常用标签的总结,简单给出自己的总结 MyBatis映射文件中的标签使用介绍1.<select>:用于编写查询语句用的标签 id:表示当前<select>标签的唯 ...

  2. 解决libcurl7.50.3在windows XP SP3 VC++ 6.0下编译报错 unresolved external symbol __imp__IdnToAscii@20 unresolved external symbol __imp__IdnToUnicode@20

    错误重现: --------------------Configuration: curl - Win32 LIB Debug DLL Windows SSPI DLL WinIDN--------- ...

  3. Ajax用法总结

    ajax:      AJAX即“Asynchronous Javascript And XML”(异步JavaScript和XML),是指一种创建交互式网页应用的网页开发技术.      AJAX ...

  4. EF6配合MySQL或MSSQL(CodeFirst模式)配置指引

    一.新建一个解决方案,包含两个项目:EF6CodeFirstMySQL.Model(动态库项目),EF6CodeFirstMySQL.Tests(控制台应用) 二.通过NuGet将EntityFram ...

  5. 安装软件 报错1304 C:\Program Files\Common Files\VMware\VMware VMRC Plug-in\Firefox\dbghelp.dll验证您对该目录具有访问权限

    现在情况是C:\Program Files\Common Files\VMware\VMware VMRC Plug-in\Firefox这个文件夹里面没有dbghelp.dll文件,就需要在百度上面 ...

  6. jquery中的append和appendTo用法

    append(content):向每个匹配的元素内部追加内容.这个操作与对指定的元素执行appendChild方法,将它们添加到文档中的情况类似. JavaScript代码 <script ty ...

  7. RHEL7学习之NTP配置

    一,安装NTP [root@localhost ~]# yum install ntp Loaded plugins: product-id, subscription-manager This sy ...

  8. (python) 标准模块sys和os的使用

    一.sys模块 包含了系统的相关的功能.我们来学习sys.argv,它包含命令行参数. 例子:定义了一个add函数,用来实现两个整数的相加. #! coding=utf-8 # usersys.py ...

  9. Python 第五天 递归,计算器(2)

    利用函数编写如下数列: 斐波那契数列指的是这样一个数列 0, 1, 1, 2, 3, 5, 8, 13, 21, 34, 55, 89, 144, 233,377,610,987,1597,2584, ...

  10. Microsoft.Office.Interop.Word.Document.Open returns null on Windows Server 2008 R2

    系统终于通过UAT,可以上线了.一遍测下来还行,可是为什么word转PDF就是不行呢?查了一下log,原来在wordApp.Documents.Open来打开生产的word文件的时候,返回一直是空.之 ...