今天学习cast,convert,datediff,dateadd

1、cast

      cast(data as Data_Type)

 

例:declare @data int

      set @data=5

      select cast(@data as char(2))+'ABC' 

 

      -- 结果为: 5 ABC

 

2、convert

      convert(data_Type,expresses(,style))   -- style 为指定日期的样式

      

  • select CONVERT(varchar,getdate(),120)
    --2009-03-15 15:10:02
  • select replace(replace(replace(CONVERT(varchar, getdate(), 120 ),'-',''),' ',''),':','')
    --20090315151201
  • select CONVERT(varchar(12) , getdate(), 111)
    --2009/03/15
  • select CONVERT(varchar(12) , getdate(), 112)
    --20090315
  • select CONVERT(varchar(12) , getdate(), 102)
    --2009.03.15
  • select CONVERT(varchar(12) , getdate(), 108)
    --15:13:26
  • 其它我不常用的日期格式转换方法:
  • select CONVERT(varchar(12) , getdate(), 101 )
    --03/15/2009
  • select CONVERT(varchar(12) , getdate(), 103 )
    --15/03/2009
  • select CONVERT(varchar(12) , getdate(), 104 )
    --15.03.2009
  • select CONVERT(varchar(12) , getdate(), 105 )
    --15-03-2009
  • select CONVERT(varchar(12) , getdate(), 106 )
    --15 03 2009
  • select CONVERT(varchar(12) , getdate(), 107 )
    -- 15, 2009
  • select CONVERT(varchar(12) , getdate(), 109 )
    --03 15 2009 
  • select CONVERT(varchar(12) , getdate(), 110 )
    --03-15-2009
  • select CONVERT(varchar(11) , getdate(), 113 )
    --15 03 2009
  • select CONVERT(varchar(12) , getdate(), 114)
    --15:15:55:717

3、datediff

      datediff(datepart,startdate,enddate)

      参数:datepart 列表

日期部分缩写
yearyy, yyyy
quarterqq, q
Monthmm, m
dayofyeardy, y
Daydd, d
Weekwk, ww
Hourhh
minutemi, n
secondss, s
millisecondms

     

 

4、 dateadd(datepart,number,date)

      

       查看系统设置的每周的第一天    -- select  @@datefirst     

 

       datediff 与 dateadd 综合使用实例:

       -- 查询当月的第一天 

       select dateadd(mm,datediff(mm,0,getdate()),0)

 

       -- 查询本周的星期一

       Select  DATEADD(wk, DATEDIFF(wk,0,getdate()),0)

 

       -- 查询一年的第一天

       Select  DATEADD(yy, DATEDIFF(yy,0,getdate()),0)

 

       -- 查询一个季度的第一天

       Select  DATEADD(qq, DATEDIFF(qq,0,getdate()),0)

 

       -- 查询上个月的最后一天(相当于本月第一天减去1天)

      Select  dateadd(day,-1,DATEADD(mm, DATEDIFF(mm,0,getdate()),  0))

 

       -- 查询去年的最后一天

       Select  dateadd(day,-1,DATEADD(yy, DATEDIFF(yy,0,getdate()),0) )

 

       -- 查询本月的最后一天
       Select  dateadd(day,-1,DATEADD(mm,  DATEDIFF(mm,0,getdate())+1,  0))

 

       -- 查询本年的最后一天

       Select  dateadd(day,-1,DATEADD(yy, DATEDIFF(yy,0,getdate())+1,0))

 

 

       -- 查询本月的第一个星期一 

       这里需要用到另外一个函数

       datepart(datepart,date)      -- 返回指定日期的指定类型的整数部分

       select  DATEADD(wk,  DATEDIFF(wk,0,dateadd(dd,6-datepart(day,getdate()),getdate())),  0) 

     

SELECT FORMAT(CONVERT(datetime, 日期), 'yyyy/MM') AS 日期, 线别, 'TNGA' + 机型 AS 机型, 产品 AS 产线, ISNULL(数量, 0) AS 返修表返修数, -- 返修记录表的数量字段映射为返修数 CAST(0 AS INT) AS 工序内合格数, -- 补充缺失字段 CAST(0 AS INT) AS 工序内不良数, -- 补充缺失字段 CAST(0 AS DECIMAL(10,4)) AS 工序内不良率 -- 补充缺失字段 FROM [192.168.10.116].[GLKANBAN].[dbo].[T_铸造_缸体缸盖返修记录表] WHERE CONVERT(datetime, 日期) >= DATEADD(MONTH, DATEDIFF(MONTH, 0, GETDATE()) - 1, 0) AND CONVERT(datetime, 日期) < DATEADD(MONTH, DATEDIFF(MONTH, 0, GETDATE()), 0) UNION ALL SELECT FORMAT(CONVERT(datetime, production_time), 'yyyy/MM') AS 日期, 线别, 'TNGA' + 机型 AS 机型, -- 统一添加TNGA前缀 CASE WHEN duty = '高压铸造' THEN '缸体' WHEN duty = '低压铸造' THEN '缸盖' ELSE duty END AS 产线, CAST(0 AS INT) AS 工序内返修数, -- 补充返修数字段 合格数 AS 工序内合格数, 不良数 AS 工序内不良数, CASE WHEN 合格数 = 0 THEN 0 ELSE ROUND(CAST(ISNULL(返修数, 0) + ISNULL(不良数, 0) AS FLOAT) / NULLIF(合格数, 0), 4) END AS 工序内不良率 FROM [192.168.10.116].GLKANBAN.[dbo].[V_铸造日报_C] WHERE CONVERT(datetime, production_time) >= DATEADD(MONTH, DATEDIFF(MONTH, 0, GETDATE()) - 1, 0) AND CONVERT(datetime, production_time) < DATEADD(MONTH, DATEDIFF(MONTH, 0, GETDATE()), 0) 改成(“返修表返修数”+“工序内合格数”+“工序内不良数”)/“工序内合格数”=工序内不良率
最新发布
12-05
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值