国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

選讀SQL經(jīng)典實例筆記05_日期運算(下)

這篇具有很好參考價值的文章主要介紹了選讀SQL經(jīng)典實例筆記05_日期運算(下)。希望對大家有所幫助。如果存在錯誤或未考慮完全的地方,請大家不吝賜教,您也可以點擊"舉報違法"按鈕提交疑問。

選讀SQL經(jīng)典實例筆記05_日期運算(下)文章來源地址http://www.zghlxwxcb.cn/news/detail-548331.html

1.?兩個日期之間相差的月份和年份

1.1.?DB2

1.2.?MySQL

1.3.?sql

select mnth, mnth/12
    from (  select (year(max_hd) - year(min_hd))*12 +
         (month(max_hd) - month(min_hd)) as mnth
    from (
  select min(hiredate) as min_hd, max(hiredate) as max_hd
    from emp
         ) x
         ) y

1.4.?Oracle

1.4.1.??sql

select months_between(max_hd,min_hd),
         months_between(max_hd,min_hd)/12
    from (
  select min(hiredate) min_hd, max(hiredate) max_hd
    from emp
         ) x

1.5.?PostgreSQL

1.5.1.???sql

select mnth, mnth/12
     from (
   select ( extract(year from max_hd) -
            extract(year from min_hd) ) * 12
          +
          ( extract(month from max_hd) -
            extract(month from min_hd) ) as mnth
     from (
   select min(hiredate) as min_hd, max(hiredate) as max_hd
    from emp
         ) x
         ) y

1.6.?SQL Server

1.6.1.???sql

select datediff(month,min_hd,max_hd),
         datediff(month,min_hd,max_hd)/12
    from (
  select min(hiredate) min_hd, max(hiredate) max_hd
    from emp
         ) x

2.?兩個日期之間相差的秒數(shù)、分鐘數(shù)和小時數(shù)

2.1.?相差的天數(shù)分別乘以24(一天的小時數(shù)),1440(一天的分鐘數(shù))和86400(一天的秒數(shù))

2.2.?DB2

2.2.1.???sql

select dy*24 hr, dy*24*60 min, dy*24*60*60 sec
     from (
   select ( days(max(case when ename = 'WARD'
                     then hiredate
                end)) -
            days(max(case when ename = 'ALLEN'
                     then hiredate
                end))
          ) as dy
    from emp
         ) x

2.3.?Oracle

2.4.?PostgreSQL

2.5.?sql

select dy*24 as hr, dy*24*60 as min, dy*24*60*60 as sec
     from (
   select (max(case when ename = 'WARD'
                   then hiredate
               end) -
           max(case when ename = 'ALLEN'
                    then hiredate
               end)) as dy
      from emp
          ) x

2.6.?MySQL

2.7.?SQL Server

2.8.?sql

select datediff(day,allen_hd,ward_hd)*24 hr,
          datediff(day,allen_hd,ward_hd)*24*60 min,
          datediff(day,allen_hd,ward_hd)*24*60*60 sec
     from (
   select max(case when ename = 'WARD'
                    then hiredate
              end) as ward_hd,
          max(case when ename = 'ALLEN'
                   then hiredate
             end) as allen_hd
    from emp
         ) x

3.?當(dāng)前記錄和下一條記錄之間的日期差

3.1.?DB2

3.1.1.??sql

select x.*,
        days(x.next_hd) - days(x.hiredate) diff
   from (
 select e.deptno, e.ename, e.hiredate,
        (select min(d.hiredate) from emp d
          where d.hiredate > e.hiredate) next_hd
   from emp e
  where e.deptno = 10
        ) x

3.2.?Oracle

3.2.1.???sql

select ename, hiredate, next_hd,
         next_hd - hiredate diff
    from (
  select deptno, ename, hiredate,
         lead(hiredate)over(order by hiredate) next_hd
    from emp
         )
   where deptno=10

3.3.?PostgreSQL

3.3.1.??sql

select x.*,
        x.next_hd - x.hiredate as diff
   from (
 select e.deptno, e.ename, e.hiredate,
        (select min(d.hiredate) from emp d
          where d.hiredate > e.hiredate) as next_hd
   from emp e
  where e.deptno = 10
        ) x

3.4.?MySQL

3.5.?SQL Server

3.6.?sql

select x.*,
        datediff(day,x.hiredate,x.next_hd) diff
   from (
 select e.deptno, e.ename, e.hiredate,
        (select min(d.hiredate) from emp d
          where d.hiredate > e.hiredate) next_hd
   from emp e
  where e.deptno = 10
        ) x

3.6.2.??datediff(x.next_hd, x.hiredate) diff

3.6.2.1.?對于MySQL 版本的DATEDIFF函數(shù),需要省略第一個參數(shù)day,并把剩下的兩個參數(shù)的順序顛倒過來

4.?一年中有多少個星期一

4.1.?方案

4.1.1.?生成一年里所有可能的日期值

4.1.2.?格式化上述日期值,并找出它們分別是星期幾

4.1.3.?統(tǒng)計每個“星期x”出現(xiàn)的次數(shù)

4.2.?DB2

4.2.1.???sql

with x (start_date,end_date)
   as (
   select start_date,
          start_date + 1 year end_date
     from (
   select (current_date -
           dayofyear(current_date) day)
           +1 day as start_date
     from t1
         )tmp
   union all
  select start_date + 1 day, end_date
    from x
   where start_date + 1 day < end_date
  )
  select dayname(start_date),count(*)
    from x
   group by dayname(start_date)

4.3.?Oracle

4.3.1.??sql

with x as (
  select level lvl
    from dual
   connect by level <= (
     add_months(trunc(sysdate,'y'),12)-trunc(sysdate,'y')
   )
  )
  select to_char(trunc(sysdate,'y')+lvl-1,'DAY'), count(*)
    from x
  group by to_char(trunc(sysdate,'y')+lvl-1,'DAY')

4.3.2.??sql

select to_char(trunc(sysdate,'y')+rownum-1,'DAY'),
        count(*)
   from t500
  where rownum <= (add_months(trunc(sysdate,'y'),12)
                   - trunc(sysdate,'y'))
  group by to_char(trunc(sysdate,'y')+rownum-1,'DAY')

4.3.2.1.?Oracle早期版本

4.4.?PostgreSQL

4.4.1.???sql

select to_char(
             cast(
      date_trunc('year',current_date)
                  as date) + gs.id-1,'DAY'),
          count(*)
     from generate_series(1,366) gs(id)
    where gs.id <= (cast
                     ( date_trunc('year',current_date) +
                          interval '12 month' as date) -
  cast(date_trunc('year',current_date)
                        as date))
   group by to_char(
               cast(
         date_trunc('year',current_date)
            as date) + gs.id-1,'DAY')

4.5.?MySQL

4.5.1.???sql

select date_format(
             date_add(
                 cast(
               concat(year(current_date),'-01-01')
                      as date),
                      interval t500.id-1 day),
                      '%W') day,
          count(*)
     from t500
   where t500.id <= datediff(
                        cast(
                      concat(year(current_date)+1,'-01-01')
                             as date),
                        cast(
                      concat(year(current_date),'-01-01')
                             as date))
   group by date_format(
               date_add(
                   cast(
                 concat(year(current_date),'-01-01')
                        as date),
                        interval t500.id-1 day),
                        '%W')

4.6.?SQL Server

4.6.1.???sql

with x (start_date,end_date)
   as (
   select start_date,
          dateadd(year,1,start_date) end_date
     from (
   select cast(
          cast(year(getdate()) as varchar) + '-01-01'
               as datetime) start_date
     from t1
         ) tmp
  union all
  select dateadd(day,1,start_date), end_date
    from x
   where dateadd(day,1,start_date) < end_date
  )
  select datename(dw,start_date),count(*)
    from x
   group by datename(dw,start_date)
 OPTION (MAXRECURSION 366)

到了這里,關(guān)于選讀SQL經(jīng)典實例筆記05_日期運算(下)的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實不符,請點擊違法舉報進行投訴反饋,一經(jīng)查實,立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費用

相關(guān)文章

  • 選讀SQL經(jīng)典實例筆記14_層次查詢

    選讀SQL經(jīng)典實例筆記14_層次查詢

    2.6.1.1.?sql 2.7.1.1.?sql 3.5.1.1.??sql 4.5.1.1.??sql 5.5.1.1.??sql 6.7.1.1.?Oracle Database 10g新增的CONNECT_BY_ROOT和CONNECT_BY_ISLEAF

    2024年02月15日
    瀏覽(20)
  • 選讀SQL經(jīng)典實例筆記08_區(qū)間查詢

    選讀SQL經(jīng)典實例筆記08_區(qū)間查詢

    1.6.3.1.?即使同一天入職的員工不止一個人,也只會返回一個值 1.6.4.1.?使用MIN函數(shù)來確保只返回一個值 2.2.2.1.?PROJ_START和PROJ_END的值決定哪些行屬于同一個區(qū)間 2.2.2.2.?如果某一行的PROJ_START值等于上一行的PROJ_END值,那么該行就是“連續(xù)”的,或者說它屬于某個組 3.4.1.1.?ora

    2024年02月16日
    瀏覽(18)
  • 選讀SQL經(jīng)典實例筆記18_Exactly
  • 選讀SQL經(jīng)典實例筆記10_高級查詢
  • 選讀SQL經(jīng)典實例筆記16_邏輯否定
  • 選讀SQL經(jīng)典實例筆記15_窗口函數(shù)

    選讀SQL經(jīng)典實例筆記15_窗口函數(shù)

    2.2.1.1.?分組不為空 2.2.1.1.1.?一個分組至少要擁有一個成員(行 2.2.1.1.2.?無法從一個空表中生成任何分組 2.2.1.2.?分組具有唯一性 2.2.1.2.1.?如果查詢語句使用了GROUP BY子句,那么通常而言SELECT列表里就不再需要使用DISTINCT了 2.2.2.1.?COUNT永遠(yuǎn)大于0 2.2.2.1.1.?無法從一個空表

    2024年02月14日
    瀏覽(15)
  • 選讀SQL經(jīng)典實例筆記22_2版增補

    選讀SQL經(jīng)典實例筆記22_2版增補

    4.1.3.1.?查找拼寫不同但發(fā)音相同的字符串 6.1.1.1.?記錄值的儀表存在誤差 6.1.3.1.?意味著數(shù)據(jù)點是正確的,但應(yīng)謹(jǐn)慎根據(jù)數(shù)據(jù)得出任何結(jié)論 9.1.2.1.?不使用CASE表達(dá)式或額外的連接操作

    2024年02月13日
    瀏覽(18)
  • 選讀SQL經(jīng)典實例筆記11_結(jié)果集變換

    選讀SQL經(jīng)典實例筆記11_結(jié)果集變換

    3.6.1.1.?為了剔除掉Null,需要調(diào)用聚合函數(shù)MAX,并基于RN執(zhí)行GROUP BY 3.9.1.1.?使用標(biāo)量子查詢基于EMPNO為每個員工排序 3.9.1.2.?針對標(biāo)量子查詢的返回值執(zhí)行GROUP BY 3.9.1.3.?使用CASE表達(dá)式和聚合函數(shù)MAX實現(xiàn)結(jié)果集變換

    2024年02月16日
    瀏覽(17)
  • 選讀SQL經(jīng)典實例筆記02_多表查詢

    選讀SQL經(jīng)典實例筆記02_多表查詢

    3.1.2.1.?排除重復(fù)項

    2024年02月12日
    瀏覽(18)
  • 選讀SQL經(jīng)典實例筆記01_檢索和排序

    選讀SQL經(jīng)典實例筆記01_檢索和排序

    SMITH ???800 ??????????????????????????0 ALLEN ??1600 ?????????300 ?????????1 WARD ???1250 ????????500 ?????????1 JONES ??2975 ?????????????????????????0 MARTIN ?1250 ??????1400 ????????1 BLAKE ??2850 ????????????????????????

    2024年02月11日
    瀏覽(17)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包