oracle/mysql sql随记

字符串分割 并 行专列

方式1 
select REGEXP_SUBSTR('01#02#03#04', '[^#]+', 1, rownum) as newport 
  from dual connect by rownum <= REGEXP_COUNT('01#02#03#04', '[^#]+');

方式2
 select aa.name
    from (with a as (select '常规检查,主动检查,专项检查,其他检查' name
    from dual)
    select regexp_substr(name, '[^,]+', 1, rownum) name
    from a
  connect by rownum <= REGEXP_COUNT(name, '[^,]+')) aa;

获取当前时间所在周的起始时间

select trunc(sysdate,'WW')  from dual;

当日分段

/*3 为每3个小时为一次分割,一天分割为8次 24/3=8 */
with tempTable as
 (
   select trunc(sysdate) + 60 * (rownum - 1) * 3 / 1440 startDate,
      trunc(sysdate) + 60 * (rownum) * 3 / 1440 endDate
     from dual
   connect by level <= 8
)
 select * from temptable;

往前推15天

 -----  oracle
  select trunc(sysdate - 1- rownum) startDate,trunc(sysdate - rownum) endDate ,rownum from dual connect by level <= 15;
 -----  mysql-1
  select 
  date_sub(CURRENT_DATE, interval (@start_rn:=@start_rn +1)+1 day) startDate,
  date_sub(CURRENT_DATE, interval (@end_rn:=@end_rn+1)  day) endDate
  from (select 1 from mysql.help_topic) a,(select @start_rn:=0,@end_rn:=0) b limit 15
 -----  mysql-2
select 
  @start_rn,
  date_sub(str_to_date('2022-05-10','%Y-%m-%d') , interval (@start_rn:=@start_rn +1)-1 day) startDate
  from (select 1 from mysql.help_topic) a,(select @start_rn:=0) b 
 where @start_rn<=datediff(str_to_date('2022-05-10','%Y-%m-%d'),str_to_date('2022-05-01','%Y-%m-%d'))

往前推7个周

   select trunc(sysdate - (to_number(to_char(sysdate - 1, 'd')) - 1) -
     (rownum - 1) * 7 ) as startDate,
      trunc(sysdate + (7 - to_number(to_char(sysdate - 1, 'd'))) -
     (rownum - 1) * 7 )as endDate,
     to_number(to_char(sysdate, 'iw')) - rownum + 1 as weekIndex
from dual
connect by level <= 7;

--先闭后开
select 
  trunc(sysdate - (to_number(to_char(sysdate - 1, 'd')) - 1) -
 (rownum - 1) * 7 ) as startDate,
 trunc(sysdate + (7 - to_number(to_char(sysdate - 1, 'd'))) -
 (rownum - 1) * 7+1) as endDate,
 to_number(to_char(sysdate, 'iw')) - rownum + 1 as weekIndex
  from dual
connect by level<= 7;

-- 例子:近7周每周个类型数量统计
with  temp_a  as
( 
    select trunc(sysdate - (to_number(to_char(sysdate - 1, 'd')) - 1) -
     (rownum - 1) * 7 ) as startDate,
      trunc(sysdate + (7 - to_number(to_char(sysdate - 1, 'd'))) -
     (rownum - 1) * 7 )as endDate,
     to_number(to_char(sysdate, 'iw')) - rownum + 1 as weekIndex
from dual
connect by level <= 7
),
temp_a2 as(
   select min(startDate) s1,max(endDate) s2 from temp_a
),
temp_b as (
  select  trunc(a.a_date) as sj,a.aydm_root ay
     from t_zhzx a
     left join temp_a2  a2 on 1=1
    where  a.a_date between a2.s1 and a2.s2
)
select a.startdate,a.enddate,
/*c_200000*/count(decode(b.ay,'200000',1,null)) c_200000,
/*c_210000*/count(decode(b.ay,'210000',1,null)) c_210000,
/*c_220000*/count(decode(b.ay,'220000',1,null)) c_220000
 from temp_a a
left join temp_b b on b.sj between a.startdate and a.enddate
group by a.startdate,a.enddate
order by  a.startdate

往前推15个月

 select 
    add_months(trunc(sysdate,'mm'),0-rownum),
    add_months(trunc(sysdate,'mm'),0-(rownum-1)) -1
  from dual connect by rownum<=15

 select add_months(trunc(sysdate, 'mm'), 1 - rownum) startDate,
        add_months(trunc(sysdate, 'mm'), 2 - rownum) endDate,
        rownum rnIndex
   from dual connect by rownum <=15;

往前推7年

 select  trunc(trunc(sysdate, 'y')-365*(rownum -1) ,'y') startDate,
        trunc(trunc(sysdate, 'y')-365*(rownum-2) ,'y')  endDate,
        rownum rnIndex
   from dual
 connect by rownum <= 7;

统计求和(总计)

select d.dm,
   decode(grouping(d.dm),1,'合计',max(d.mc)) mc,
  nvl(sum(p2.product), 0) "productTotal"
from t_dic_pcs d
left join (  select '1' comp_dm,1 product from dual  ) p2  on p2.comp_dm = d.dm
 where d.fjdm = '320582' 
 group by rollup (d.dm)
 order by 1;

先查看数据文件存放路径,统一路径

select * from dba_data_files;
比如路径为F:\app\oradata\xxx.dbf
把路径中的xxx.dbf换成jnga_01.dbf 然后填入下面datafile ''的引号中

创建表空间

create tablespace jnga
datafile ''
size 50m
autoextend on next 20m
maxsize unlimited;
--创建用户
create user jnga identified by jnga
default tablespace jnga;
--用户授权
grant connect,resource,unlimited tablespace,dba to jnga;

获取所有叶子节点

select t.code,t.name,level lvl,connect_by_isleaf from tableA  t
where connect_by_isleaf =1
start with t.code='xxxx'
connect by prior t.id=t.parent_id;

select t.code,t.name,level lvl,connect_by_isleaf from tableA  t
start with t.code='xxxx' connect by prior t.id=t.parent_id;

select t.code,t.name,level lvl,connect_by_isleaf from tableA  t
start with t.code='xxxx' connect by prior t.parent_id=t.id;

分析性函数 partition by

--row_number() 顺序排序
 select * from (
       select deptid ,row_number() over(partition by deptid order by salary) my_rank ,deptid,USERID,salary       
   from tsaler;
 ) where my_rank=1;

--rank() (跳跃排序,如果有两个第一级别时,接下来是第三级别)
select deptid ,rank() over(partition by deptid order by salary) my_rank,deptid,USERID,salary from tsaler;

--dense_rank()(连续排序,如果有两个第一级别时,接下来是第二级)
select dense_rank() over(partition by deptid order by salary) my_rank,deptid,USERID,salary from tsaler;

delete from t_qy where rowid in (
select rowid from (select id,rowid rn1,row_number() over(partition by id order by id) rn from t_qy t )
where rn !=1)
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,919评论 6 502
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,567评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 163,316评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,294评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,318评论 6 390
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,245评论 1 299
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,120评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,964评论 0 275
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,376评论 1 313
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,592评论 2 333
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,764评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,460评论 5 344
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,070评论 3 327
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,697评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,846评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,819评论 2 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,665评论 2 354