189 8069 5689

oracle如何1周,oracle每周第一天

Oracle计算周数的几种方式

比如星期一到星期天算一周 查2011年7月完整周数 select max(count1) - 1 from (SELECT count(1) count1 FROM DUAL WHERE TO_CHAR(ADD_MONTHS(LAST_DAY(to_date('201107', 'yyyyMM')), -1) + LEVEL, 'DAY') = '星期一' CONNECT BY LEVEL

让客户满意是我们工作的目标,不断超越客户的期望值来自于我们对这个行业的热爱。我们立志把好的技术通过有效、简单的方式提供给客户,将通过不懈努力成为客户在信息化领域值得信任、有价值的长期合作伙伴,公司提供的服务项目有:空间域名、虚拟空间、营销软件、网站建设、迪庆州网站维护、网站推广。

如何查询oracle数据库一周的数据

参考 oracle11g行变列两种办法的比较:

方法1:优点是分析函数,缺点:返回log,低效,

select link_pid, replace(strs,',','|') all_forms

from

(select t.link_pid,

wmsys.wm_concat(t.form_of_way)

over(partition by t.link_pid order by t.form_of_way ) strs,

row_number() over(partition by t.link_pid order by t.form_of_way) RN,

count(1) over(partition by t.link_pid ) CNT

from rd_link_form t

) where RN=CNT

方法2:优点是高效,返回char,缺点:不是分析函数

select t.link_pid,

listagg(t.form_of_way, '|')

within group (order by t.form_of_way ) all_forms

from rd_link_form t

group by t.link_pid

listagg()需在11.2版本下才行

两种方法的比较:依link_pid去重后有23万的数据量,方法1的wmsys.wm_concat用3小时看不到结果,方法2的listagg用80秒看到结果

【我以字典表user_tab_columns改写了上述SQL,如下,大家直接执行就行:】

方法1:

select table_name, replace(strs, ',', '|') all_forms

from (select t.table_name,

wmsys.wm_concat(t.COLUMN_NAME) over(partition by t.table_name order by t.COLUMN_NAME) strs,

row_number() over(partition by t.table_name order by t.COLUMN_NAME) RN,

count(1) over(partition by t.table_name) CNT

from user_tab_columns t)

where RN = CNT

方法2:

select t.table_name,

listagg(t.COLUMN_NAME, '|')

within group (order by t.COLUMN_NAME ) all_forms

from user_tab_columns t

group by t.table_name

大家可以直接在自己的pl/sql中运行上述SQL

ORACLE数据库查询一周以内的数据怎么写

截取本周第一天:

SQL select sysdate,trunc(sysdate,'d') from dual;

SYSDATE TRUNC(SYSDATE,'D')

------------------- -------------------

2009-03-24 21:29:32 2009-03-22 00:00:00


文章标题:oracle如何1周,oracle每周第一天
当前地址:http://cdxtjz.cn/article/dscshpd.html

其他资讯