oracle常规使用(一)
oracle和mysql目前数据库中的巨头,之前公司一直使用的是mysql,今年对oracle有了初步的接触,简单介绍使用过程中的一些总结
特殊sql
distinct
- 通过distinct关键字针对字段去重。 正常后面跟一个字段。就已该字段去重。
项目中遇到表中无主键,但是某个字段不能重复。
正常sql:
select t.*,t.rowid from stage t where t.intersection_id=2;

去重sql:
select tt.*
from stage tt
where tt.rowid in (select
max(t.rowid)
from stage t
where t.intersection_id = 2
group by t.stage_id)

需要匹配id串里的内容
select
*
from stage
where stage_id in (1,9,10,5)
and intersection_id = 1031739143323648;
现在需要按照stage_id 1,9,10,5的顺序排列 '1,1,9,2,10,3,5,4'奇偶分离得到'1,9,10,5'和'1,2,3,4'前者是stageid后者是顺序序号
select
*
from stage
where stage_id in (1,9,10,5)
and intersection_id = 1031739143323648
order by decode(stage_id , 1,1,9,2,10,3,5,4);
批量更新,但是批量成功返回的是-1
开始认为很是奇怪,批量更新成功了,按照道理来说应该是返回批量操作的条数.
返回负数,是由于mybatis的defaultExecutorType的引起的,defaultExecutorType有三个执行器SIMPLE、REUSE和BATCH。
其中BATCH可以批量更新操作缓存SQL以提高性能,但是有个缺陷就是无法获取update、delete返回的行数
如果确定要拿到更新条数,defaultExecutorTypes设置成SIMPLE就可以
<update id="updateBatch" parameterType="java.util.List">
<foreach collection="list" item="item" index="index" open="begin" close=";end;" separator=";">
update T_CITY_INDEX t
set
t.city_name= #{item.cityName,jdbcType=VARCHAR} ,
t.district_name= #{item.districtName,jdbcType=VARCHAR} ,
where t.id = #{item.id,jdbcType=NUMERIC}
</foreach>
</update>
时间格式化
oracle 和 mysql 中对时间格式化都是这样,和我们Java中的格式化时间格式有所不同,YYYY-MM-DD hh24:mi:ss , 不区分大小写
to_char(t.start_time , 'YYYYMMDDHH24mmss')<=to_char(#{endTime},'YYYYMMDDHH24mmss') 将date格式时间格式化字符串比较
to_number() 将数字型字符串格式化成数字
行列互转
- 在实际开发中我们可能遇到行列互转的情况,这个时候如果先查出来通过Java做转换,最终是可以实现效果,但是效率将会大大降低.
oracle提供了 pivot 和 unpivot 关键字 ,mysql中没有尝试过 , 有兴趣的可以尝试下mysql中是否有这两个关键字 .下面看看实际的操作
应用场景
列转行
首先我们看下图中的sql查出来的数据是我再业务开发中需要的一个汇总数据.

但是这个数据不是完全符合我们的需求.我们在外层(Java)中是用实体接受onlineCount,offlineCount数据的,我们提供到web端也是通过这两个字段.但是
现在的情况我们Java接受到的是个集合,集合中的实体的属性是state,count这个两个数据,state的值是onlineCount或offlineCount.这很明显不符合业务需求.
但是我们发现只需要将列转成行我们就很容易完成实体的映射.下面的格式才是我们需要的

那么如何列转行呢,oracle提供了我们方式(pivot),我们通过这个关键字可以将列名转成行名.默认是会将列的值加上"",这个时候我们正常都需要为行名(属性名)添加别名
具体sql
select *
from (select case t.state
when 0 then
'onlineCount'
else
'offlineCount'
end as state,
count(1) as count
from rfid_device t
group by t.state
order by t.state)
pivot(sum(count)
for state in('onlineCount' onlineCount, 'offlineCount' offlineCount))

ps: pivot(func for field in ("col1" col1,"col2" col2,...,"coln" coln))
着我们可以理解成语法来记忆
pivot : 关键字
for : 关键字 (固定语法)
field : 列名(原本的属性名)
in : 关键字
coln : 是源数据中的field属性的具体值,就是我们转换后的属性值
func : 是个聚合函数(聚合函数里的对象正常就是转换后的内容)
建议大家对照数据查看,这样比较容易理解 , 上面的coln 是 "coln" 的别名
行转列
上面通过pivot关键字我们是实现了列转行,有来必有往,所以我们有必要了解一下行转列的情况,oracle提供的也很有意思unpivot , 顾名思义就是列转行的反向-->行转列

总结
我们通过上面两个案例可以发现,这两个是通用的.意思是说可以通过unpivot 将pivot的数据转回去.因为pivot后的属性其实是列值,而unpivot就是将属性名转成列值
oracle常规使用(一)的更多相关文章
- oracle常规任务
# su - oracle oracle> sqlplus "/as sysdba" SQL> exec dbms_scheduler.disable('MONDA ...
- oracle常规操作
dbms_job.broken(job1,true);
- Toad for Oracle 使用文档
Toad®for Oracle 版本 12.0.1 发行说明 30 July 2013 目录 欢迎使用 Toad for Oracle 版本更新 解决的问题和改进 已知问题 第三方已知问题 升级和兼容 ...
- Oracle排错总结
一.Oracle常规恢复之不安全恢复 http://www.cnblogs.com/jyzhao/p/4723994.html#2.11
- Oracle联合注入总结
Oracle常规联合注入 Oracle Database,又名Oracle RDBMS,或简称Oracle.是甲骨文公司的一款关系数据库管理系统. Oracle对于MYSQL.MSSQL来说意味着更大 ...
- Oracle Recovery 01 - 常规恢复之完全恢复
背景:这里提到的常规恢复指的是数据库有完备可用的RMAN物理备份. 实验环境:RHEL6.4 + Oracle 11.2.0.4 DG primary. 一.常规恢复之完全恢复:不丢失数据 1.1 单 ...
- Oracle Recovery 02 - 常规恢复之不完全恢复
背景:这里提到的常规恢复指的是数据库有完备可用的RMAN物理备份. 实验环境:RHEL6.4 + Oracle 11.2.0.4 单实例. 二.常规恢复之不完全恢复:部分数据丢失 2.1 重做日志文件 ...
- 本文将详细介绍oracle 10g OEM常规错误
本文将详细介绍oracle 10g OEM常规错误-------Unknown host specified解决方法,需要了解的朋友可以参考下 详细出处参考:http://www.jb51.net/a ...
- MySQL、Oracle、DB2等数据库常规排序、自定义排序和按中文拼音字母排序
MySQL常规排序.自定义排序和按中文拼音字母排序,在实际的SQL编写时,我们有时候需要对条件集合进行排序. 下面给出3中比较常用的排序方式,mark一下 1.常规排序ASC DESC ASC 正序 ...
随机推荐
- Appium+python自动化(十八)- 你难道是猴哥失散多年的混血弟弟还是妹妹???- Monkey事件(超详解)
操作事件简介 Monkey所执行的随机事件流中包含11大事件,分别是触摸事件.手势事件.二指缩放事件.轨迹事件.屏幕旋转事件.基本导航事件.主要导航事件.系统按键事件.启动Activity事件.键盘事 ...
- spark 源码分析之十四 -- broadcast 是如何实现的?
本篇文章主要剖析broadcast 的实现机制. BroadcastManager初始化 BroadcastManager初始化方法源码如下: TorrentBroadcastFactory的继承关系 ...
- 20141209-基本概念-BlogEngine.NET(1)-笔记
最近在读BlogEngine.NET3.1源代码,希望能坚持到底吧. 刚接触源代码,没有思路,于是读了14篇关于BlogEngine.Net1.4.5的系列博客,地址:http://www.cnblo ...
- 【基本数据结构之堆】-C++
注意:这篇博客讲的是手写堆,喜欢用C++自带数据结构模拟的慎入 今天我们来聊一聊一种奇怪 的数据结构: 堆 为什么说这个数据结构有点奇怪呢? 先看看其他的在我眼里是正常的数据结构: 队列(近似于排队) ...
- 【攻略】百度货币识别API,搞定防诈骗的应用小程序
1.需求及方案: 近两年用外币进行诈骗的案件很多.例如:2015年12月,一安徽诈骗团伙,用不值1角人民币的50印蒂(intis,秘鲁旧货币,1991年发行新货币后已停止流通,目前无货币价值,仅有&q ...
- 鸽巢原理及其扩展——Ramsey定理
第一部分:鸽巢原理 咕咕咕!!! 然鹅大家还是最熟悉我→ a数组:but 我也很重要 $:我好像也出现不少次 以上纯属灌水 文章简叙:鸽巢原理对初赛时的问题求解以及复赛的数论题目都有启发意义.直接的初 ...
- 2019牛客多校第二场H-Second Large Rectangle
Second Large Rectangle 题目传送门 解题思路 先求出每个点上的高,再利用单调栈分别求出每个点左右两边第一个高小于自己的位置,从而而得出最后一个大于等于自己的位置,进而求出自己的位 ...
- hdu6395 Sequence(分段矩阵快速幂)
Sequence 题目传送门 解题思路 可以比较容易的推出矩阵方程,但是由于p/i向下取整的值在变,所以要根据p/i的变化将矩阵分段快速幂.p/i一共有sqrt(p)种结果,所以最多可以分为sqrt( ...
- mysql协议分析1---报文的格式和基本类型
navicat 和 mysql 是一对好基友,每天都有非常频繁的交流,主人在navicat上写下每条sql语句,轻轻的点了下执行按钮,navicat就飞快的把主人的指令传送到mysql那里,mysql ...
- Java生鲜电商平台-统一异常处理及架构实战
Java生鲜电商平台-统一异常处理及架构实战 补充说明:本文讲得比较细,所以篇幅较长. 请认真读完,希望读完后能对统一异常处理有一个清晰的认识. 背景 软件开发过程中,不可避免的是需要处理各种异常,就 ...