在开发过程中遇到的Oracle的坑及开发技巧
本人自毕业以来一直从事java软件开发工作,工作中大部分数据库都是使用的Oracle,碰到的问题总结一下(随时更新)。
1.sql中使用group by 分组时select 后面直接出现的字段也应当出现在group by 的后面;
select id,name from t_user group by id,name<!--正确-->
select id,name from t_user group by id<!--错误-->
2.使用mybatis查询的结果集使用java类接收的话字段的大小写由java类字段大小写决定,而使用Map接收的话Map的键key会是大写,如果需要小写可以使用字段别名;
<select resultType="java.util.Map"> <!--Map中键为ID和NAME-->
select id,name from t_user
</select> <select resultType="java.util.Map"> <!--Map中键为id和name-->
select id "id",name as "name" from t_user
</select>
3.wm_concat(column)是Oracle中的函数,用来合并同列字段,在低版本的oracle中返回的是varchar值,而在高版本的oracle中的值却是clob属性!!!(使用Map接收查询结果集要注意)
select order_code,wm_concat(project_name) from t_order group by order_code;
select order_code,to_char(wm_concat(project_name)) from t_order group by order_code
4.查询语句使用order by 排序时,如果order by 后面跟的时单纯的字符串的话,并不会报错。
之所以会发现这个问题是因为项目中的列表查询有一个需求:列表的排序需要从数据库排序。即从前台传入需要排序的字段与排序方式,mybatis的#{}会将sql预编译一遍,然后在传入的变量前后加上" ' "插入在相应的位置,导致实际执行的sql并不符合排序的需求,不得已使用 ${}传入变量。
--orderBy = user_code desc
select * from t_user ordey by #{orderBy};
select * from t_user order by 'user_code desc'; select * from t_user ordey by ${orderBy};
select * from t_user order by user_code desc;
5、oracle 某字段为空时,使用is null才能判断出改字段的值,字段不为空时使用= 与 != 均无法判断出来
创建一张测试表,字段与数据如图:
数据:
(1)执行sql
select * from t_test where test_number = '55555'
结果:
没什么问题。
(2)执行sql
select * from t_test where test_number != '55555'
结果:
出现问题了,查询 != 的条件该列为空的情况并没有出现在查询结果中。
(3)执行sql
select * from t_test where test_number is null
结果:
(4)执行sql
select * from t_test where test_number is not null
结果:
由此可见,当查询条件中的字段包含空值时,这一部分值需要通过 is null 或者 is not null 才能筛选出来!!!
6、使用mybatis 的selectKey返回新增数据的id,需要注意序列需要至少调用一次nextval后,才能使用currval返回当前序列中的值
新增数据自增id序列及触发器sql如下:
-- Create sequence
create sequence t_test_id_seq
minvalue 1
maxvalue 999999999999999999999999
start with 1
increment by 1
cache 20; -- Create trigger
CREATE OR REPLACE TRIGGER t_test_id_trig
BEFORE INSERT OR UPDATE ON t_test
FOR EACH ROW
DECLARE
v_newVal NUMBER(12) := 0;
v_incval NUMBER(12) := 0;
BEGIN
IF INSERTING AND :new.id IS NULL THEN
SELECT t_test_id_seq.NEXTVAL INTO v_newVal FROM DUAL;
IF v_newVal = 1 THEN
SELECT NVL(max(id), 0)
INTO v_newVal
FROM t_test;
v_newVal := v_newVal + 1;
LOOP
EXIT WHEN v_incval >= v_newVal;
SELECT t_test_id_seq.nextval
INTO v_incval
FROM dual;
END LOOP;
END IF;
:new.id := v_newVal;
END IF;
END;
在mapper.xml中写法如下
<insert id="insertTestData" parameterType="com.bvdata.test.Test">
insert into t_test (test_number) values (#{test_number})
<selectKey keyProperty="id" resultType="Integer" order="AFTER">
select t_test_id_seq.currval from dual
</selectKey>
</insert>
当创建完成序列t_test_id_seq后,第一次执行sql
select t_test_id_seq.currval from dual
会出现错误:
当执行sql
select t_test_id_seq.nextval from dual;
select t_test_id_seq.currval from dual;

这时currval就可以直接使用了。
在开发过程中遇到的Oracle的坑及开发技巧的更多相关文章
- sass开发过程中遇到的几个坑
1.安装sass被墙的问题 安装完`ruby`后,打开`ruby cmd` 输入`gem install sass`,安装失败,有可能是镜像源的问题,也有可能是墙的问题. 因为公司内网的奇葩限制,各种 ...
- 【开发技巧】再见,BLE的那些坑!
蓝牙,平常你用的多吗?上班路上戴着蓝牙耳机听音乐.看视频打开蓝牙分享个人热点给小伙伴们解锁共享单车时,打开蓝牙就能迅速解锁...... BLE-蓝牙低能耗技术,方便了我们的生活,但是开发者在开发过程中 ...
- 记一次开发过程中,iview遇到的一些坑以及解决办法
写在开头:本次项目采用的是vue2.0+iview3.0,最近公司没啥事,来总结一下开发过程中遇到的问题. 1.Modal关闭问题 需求背景:modal框里面是个form表单,点击确定之后,先验证fo ...
- 小程序红包开发跳坑记 微信小程序红包接口开发过程中遇到的问题 微信小程序红包开发
现在做小程序的越来越多,商家推广也是一个瓶颈,谁不发点红包,都很难找到人来用你的微信小程序了.于是不管你开发什么小程序功能,你或多或少都要用到小程序来发红包吧. 我们自己之前做公众号发红包,做了两三 ...
- 微信小程序红包开发 小程序发红包 开发过程中遇到的坑 微信小程序红包接口的
微信小程序红包开发 小程序发红包 开发过程中遇到的坑 微信小程序红包接口的 最近公司在开发一个小程序红包系统,客户抢到红包需要提现.也就是通过小程序来给用户发红包. 小程序如何来发红包呢?于是我想 ...
- android开发过程中遇到的坑
在android的学习过程中,会有很多坑,我会把我遇到的,一一列下来,方便后来者查阅! 1:android-support-v4.jar and android-support-v7-appcompa ...
- ionic开发过程中遇到的一些坑!
总结一些:在使用 ionic 开发过程中所遇到的问题. 问题一:Cannot find module '@ionic/app-scripts' 描述:使用 ionic start 项目的时候,项目安装 ...
- EntityFramework CodeFirst SQLServer转Oracle踩坑笔记
接着在Oracle中使用Entity Framework 6 CodeFirst这篇博文,正在将项目从SQLServer 2012转至Oracle 11g,目前为止遇到的问题在此记录下. SQL Se ...
- 客户关系管理系统(CRM)的开发过程中使用到的开发工具总结
开发<客户关系管理系统(CRM)>软件过程,也就是一个标准的Winform程序的开发过程,我们可以通过这个典型的软件开发过程来了解目前的开发思路.开发理念,以及一些必要的高效率手段.本篇随 ...
随机推荐
- S3C2440内存控制器详解
S3C2440A Memory Map after Reset S3C2440的内存空间划分为不同的块,当CPU向内存控制器发出地址,内存控制器根据地址范围,发出对应片选信号到片选引脚,实现对不同设备 ...
- PAT (Advanced Level) 1144~1147:1145Hash二次探查 1146拓扑排序 1147堆
1144 The Missing Number(20 分) 题意:给定N个数的序列,输出不在序列中的最小的正整数. 分析: 1.给定的N个数可能为正,可能为负,可能重复. 2.由于N≤105,所 ...
- 第3节 sqoop:2、sqoop的基本简介和安装
3. sqoop数据迁移 3.1.概述 sqoop是apache旗下一款“Hadoop和关系数据库服务器之间传送数据”的工具. 导入数据:MySQL,Oracle导入数据到Hadoop的HDFS.HI ...
- Swift 语法糖then
then是一个swift初始化库,只有80几行的代码库,确可以让初始化变得很优雅. 1.使用then初始化AnyObject,这里以初始化控件为例 lazy var label = UILabel() ...
- 原型与继承与class
对象有属性(专业点叫静态属性)和方法(专业点叫静态方法)和原型属性和原型方法 除了系统自带的那么几百万个对象,我们自己写在js的创建的对象,自定义的对象,都来自对象的构造函数,用来构造对象的函数,叫做 ...
- eshop2-linux 软件源配置 and 建议
1. 阿里云源配置:http://mirrors.aliyun.com/ 2. 源配置 2.1 sudo mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.r ...
- 吴裕雄 Bootstrap 前端框架开发——Bootstrap 字体图标(Glyphicons):glyphicon glyphicon-play-circle
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta name ...
- Windows安装tensorflow,配置vs2013,anaconda3.4,cudn9.0,cudnn7.0和pycharm
前言 最近要开始学习深度,那么首先在电脑上安装tensorflow.但是我不知道是配置版本的问题,还是安装失误的问题,我安装了很久没有安装成功,最后重装了电脑,并且融合了所有的网上可以查到的方案才安装 ...
- JuJu团队11月28号工作汇报
JuJu团队11月28号工作汇报 JuJu Scrum 团队成员 今日工作 剩余任务 困难 于达 解决了数据接口的bug 生成generator形式, 并用熟悉Julia处理数据的方法 处理数据步 ...
- P1010 一元多项式求导
1010 一元多项式求导 (转跳点: