Oracle 使用总结(SQL语句)
Oracle分页查询(对比Mysql limit)
因为Oracle不像Mysql一样使用limit进行分页,故做如下总结
首先需要明确两个概念。rowid, rownum。
rowid是物理地址,用于定位oracle中具体数据的物理存储位置,而rownum则是sql的输出结果排序。通俗的讲:rowid是相对不变的,rownum会变化,尤其是使用order by的时候。
因为rownum是对结果集加的一个伪列,即先查到结果集之后再加上去的一个列。
简单的说,rownum是对符合条件结果的序列号。它总是从1开始排起的,所以选出的结果不可能跳过1,而有其他大于1的值。
或者说,rownum是一个动态的,根据新的结果集实时变化的
select t.*, rownum from test_ljb t where rownum >1; --大于2、3或者其他任何大于1的值,结果相同。
我们发现没有符合条件的记录。
根据原理,rownum是对结果集的从1开始排。那么以上的语句的结果集是什么呢?
事实上,当执行完from test_ljb时,我们可以把他当作时一个结果表,rownum是从1-10。
然后,重点,当我们执行过滤条件,rownum>1
时,第一条记录不满足,剔除。这个时候,新的结果集产生了,原来的第二条记录就成了第一条,相应的rownum变为了1-9。
再次比较原来的第一条,现在的第二条记录,他的rownum也是1,也不满足,rownum是1-8。
以此类推,流水的记录,铁打的rownum从1开始。所以,直到rownum是1,还不满足。所以最后没有记录被筛选出来,也没了rownum。
分页查询示例语句
select * from
(
select t.*,rownum r from test_ljb t
)t
where t.r>3 and t.r<6
Oracle 常用函数总结
concat(X,Y) 连接两字符串
在这里插入代码片
ABS(X) 绝对值round(X,Y) 四舍五入
to_char(d|n[,fmt]) 把日期和数字转换为制定格式的字符串。Fmt是格式化字符串
NVL(X,VALUE) 如果X为空,返回value,否则返回X
NVL2(x,value1,value2) 如果x非空,返回value1,否则返回value2
使用示例
oracle SQL语句执行顺序
(8)SELECT (9) DISTINCT (11)
(1) FROM
(3) JOIN
(2) ON
(4) WHERE
(5) GROUP BY
(6) WITH {CUBE | ROLLUP}
(7) HAVING
(10) ORDER BY
1)FROM:对FROM子句中的表执行笛卡尔积(交叉联接),生成虚拟表VT1。
2)ON:对VT1应用ON筛选器,只有那些使为真才被插入到TV2。
3)OUTER (JOIN):如果指定了OUTER JOIN(相对于CROSS JOIN或INNER
JOIN),保留表中未找到匹配的行将作为外部行添加到VT2,生成TV3。如果FROM子句包含两个以上的表,则对上一个联接生成的结果表和下一个表重复执行步骤1到步骤3,直到处理完所有的表位置。4)WHERE:对TV3应用WHERE筛选器,只有使为true的行才插入TV4。
5)GROUP BY:按GROUP BY子句中的列列表对TV4中的行进行分组,生成TV5。
6)CUTE|ROLLUP:把超组插入VT5,生成VT6。
7)HAVING:对VT6应用HAVING筛选器,只有使为true的组插入到VT7。
8)SELECT:处理SELECT列表,产生VT8。
9)DISTINCT:将重复的行从VT8中删除,产品VT9。
10)ORDER BY:将VT9中的行按ORDER BY子句中的列列表顺序,生成一个游标(VC10),生成表TV11,并返回给调用者。
在oracle 将多行数据进行拼接转为字符串进行返回
(select LISTAGG(GGSML.SKU_ID, ',') WITHIN GROUP (ORDER BY GGSML.SKU_ID) as rountCode from GS_GOODS_SKU_MAPPING GGSML where GGSML.SUP_SKU_ID=sku.sku_id and GGSML.GOODS_TYPE=3) as rountCode,