SpringBoot集成Oracle实战和坑
前言
前段时间搞了一个oracle的项目,耗费了很多时间,现在项目整体上线了,在此记录下实战过程以及遇到的坑,有需要的网友也可以直接拿去使用。
1.导包
springboot版本:2.1.3。最好是10以上的,网上说10以下的有些问题。我自己没测试。
<!--oracle驱动--> <dependency> <groupId>com.oracle</groupId> <artifactId>ojdbc6</artifactId> <version>11.2.0.3</version> </dependency>
2. 配置文件:数据库信息
# oracle datasource 数据库访问配置 默认 spring.datasource.platform.url = jdbc:oracle:thin:@127.0.0.1:1521/orcl spring.datasource.platform.username = LOCAL spring.datasource.platform.password = LOCAL spring.datasource.platform.driver-class-name = oracle.jdbc.OracleDriver
注意:这里orcl是服务名,而不是sid。如果是sid,则是1521:sid。两个符号代表的意义不同,一般运维给的都是服务名,如果连接不上再确认密码无误后,可以和同事确认下,是个小坑
还有这里的配置名称多了platform.是因为我用的分库分表,自配的数据库config。如果你不是,而是那种自动获取的话需要去掉,否则spring获取不到就无法连接。
这里username不允许是管理员级别,否则会报连接数据库错误。
辟谣
有的博主不自己实验就瞎说,上面报错说:用户名后加上as sysdba,就可以解决。我自己试了一下启动的确是不报连接数据库错误了,但是在查询数据库时却会报找不到表或者视图。还是推荐你自己建立一个用户,这个和oracle自己本身的规则有关。
3.代码
像我们通常使用的controller、service、mapper、model等都可以通过工具生成(idea),可以参考我的这篇文章,里面有配好的oracle模板以及详细教程:https://blog.csdn.net/zth_killer/article/details/130225708
具体代码我就不贴了,网址里也有具体效果图。配号模板,全程一键自动即可。但是如果你用的不是idea就可能要手动写了。这里我说几个手写时的注意点,主要是xml的:
1.Oracle建表时没有自增ID,需要配置。我用的都是varchar2没有配置自增的,需要网友自己搜索下;
2.虽然我不是自增,但是模板是按照自增的设计的(涉及到初始模板)。所以如果你和我一样的话,新增需要手动加下,然后修改有需要的话也改一下。不推荐改动模板;
3.oracle中是没有limit分页的,所以需要注意修改,我的模板中没有因为这次需求只有一个分页,需求量大的可以自己加上,研究一下很简单;
其次我们有的会集成MyBatis分页,如果传入page参数就会触发,然后sql报错;
4.手动写代码时,字段名需要用“”包含,否则会报sql执行错误;
问题更新
1.一直报这个驱动类找不到,但是这个驱动类jar包已经添加到项目了,并且我也反编译jar包,确认路径是对的。后来将target文件夹删掉重新编译,就没有问题了;
2.在上面中说到字段名需要加“”,是因为有的字段是特殊字段,比如DATE等,所以在模板中就直接都加上了;
3.其实使用管理员登录也是可以,但是查询时需要加上库名.表名(自身感觉多此一举,不推荐);
#java##实战##oracle#今天就到这里吧,感觉有用的小伙伴可以点个赞;有其它意见和问题的也可以在下面评论,看到后会及时回复。你的支持就是我更新的最大动力!
不秃头