SpringBoot整合Mybatis连接Oracle数据库

xxkfz
• 阅读 1838

学习目标:

通过本篇文章掌握如何使用SpringBoot整合Mybatis来连接Oracle数据库进行基本的数据库操作。 在之前的项目中,大多使用的是Mysql数据库,但在企业中使用的是Oracle数据库,下面就来简单的介绍下如何使用SpringBoot整合Mybatis的方式操作Oracle数据库。


学习内容:

基本准备

首先下载并安装Plsql,并连接Oracle数据库。 一、下载PLSQL的安装包。注:安装包可以到下面网盘里面下载。 链接:https://pan.baidu.com/s/1cUU4tyilFr4iMqrLDjIXRQ 提取码:n25u 二、安装并配置。 2.1、解压所下载的PLSQL安装包、进行默认安装即可。安装完成后可以使用以下的注册信息完成注册。 Product Code(产品编号):4t46t6vydkvsxekkvf3fjnpzy5wbuhphqz serial Number(序列号):601769 password(口令):xs374ca 2.2、解压下载的 SpringBoot整合Mybatis连接Oracle数据库)文件,此时我解压的目录为:SpringBoot整合Mybatis连接Oracle数据库 2.3、打开PLSQL软件,并找到上方的工具栏Tools——>Preferences...、接下来配置Oracle客户端软件。 D:\plsql\PLSQL9.0\instantclient-basic-nt-11.2.0.4.0\instantclient_11_2 D:\plsql\PLSQL9.0\instantclient-basic-nt-11.2.0.4.0\instantclient_11_2\oci.dll 如下图所示: SpringBoot整合Mybatis连接Oracle数据库 2.4、在D:\plsql\PLSQL9.0\instantclient-basic-nt-11.2.0.4.0\instantclient_11_2 依次创建文件夹NETWORK\ADMIN,如下图所示: SpringBoot整合Mybatis连接Oracle数据库 接下来在ADMIN文件夹下面创建文件SpringBoot整合Mybatis连接Oracle数据库 tnsnames.ora文件配置内容如下:

APPORCL =
  (DESCRIPTION =
    (ADDRESS = (PROTOCOL = TCP)(HOST = 172.12.100.12)(PORT = 1521))
    (CONNECT_DATA =
      (SERVER = DEDICATED)
      (SERVICE_NAME = orcl)
    )
  )

说明: 在上面的配置信息中: APPORCL :连接名 HOST :远程连接数据库的IP地址 SERVICE_NAME :数据库名

注:以上配置信息,根据具体情况有所变动。

2.5、配置环境变量。
在系统变量中添加以下环境变量:
a、变量名为NLS_LANG,变量值为 AMERICAN_AMERICA.AL32UTF8
b、变量名为TNS_ADMIN,变量值为D:\plsql\PLSQL9.0\instantclient-basic-nt-11.2.0.4.0\instantclient_11_2\NETWORK\ADMIN

项目案例

注意:由于Oracle数据库是收费的,所以oracle数据库的驱动依赖,Maven仓库不提供,需要我们进行手动添加。 一、下载Oracle的jdbc驱动包。(下载完成后放在了E盘根目录下面。E:\ojdbc8.jar) 二、将jar包添加到本地仓库。配置好完成Maven的环境变量后,在dos下执行命令mvn install:install-file -DgroupId=com.oracle -DartifactId=ojdbc8 -Dversion=8.2.0.2.0 -Dpackaging=jar -Dfile=E:\ojdbc8.jar 三、现在可以在pom文件中引入了。

    <dependency>
            <groupId>com.oracle</groupId>
            <artifactId>ojdbc8</artifactId>
            <version>8.2.0.2.0</version>
    </dependency>
四、在项目的application.properties配置文件中进行配置数据库信息。
server.port=8081
#mybatis.config-locations=classpath:mybatis/mybatis-config.xml
mybatis.type-aliases-package=com.example.entity
mybatis.mapper-locations=classpath:mapper/*.xml
#oracle database  配置
spring.datasource.driver-class-name=oracle.jdbc.driver.OracleDriver
spring.datasource.url=jdbc:oracle:thin:@192.168.X.X:1521:数据库名
spring.datasource.username=root
spring.datasource.password=root
spring.datasource.max-idle=10
spring.datasource.max-wait=10000
spring.datasource.min-idle=5
spring.datasource.initial-size=5

#控制台打印sql日志
mybatis.configuration.log-impl= org.apache.ibatis.logging.stdout.StdOutImpl
#设置驼峰
mybatis.configuration.map-underscore-to-camel-case=true
五、由于具体操作和操作Mysql大致类似,只是连接数据库的一些配置信息,驱动有所区别;项目的其他内容请参考文章: [SpringBoot总结(十)——SpringBoot+Mybatis实现数据库的CRUD(从创建到实现【超详细附代码】)](https://blog.csdn.net/weixin_43759352/article/details/104494336)

本篇文章到这里就基本结束了,如果这篇文章对你有帮助,希望大家能留下你的点赞、 关注、 分享、 留言❤️❤️❤️

SpringBoot整合Mybatis连接Oracle数据库

2021年05月19日

点赞
收藏
评论区
推荐文章
blmius blmius
2年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
Wesley13 Wesley13
2年前
RAC环境单实例启动数据库收到ORA
     在RAC环境中,如果你在没有启动节点的集群服务的情况下单实例启动数据库,将收到类似如下的报错:\oracle@rhel1u01\$sqlSQL\Plus:Release10.2.0.5.0ProductiononTueApr215:00:272013Copyright(
Stella981 Stella981
2年前
Python3:sqlalchemy对mysql数据库操作,非sql语句
Python3:sqlalchemy对mysql数据库操作,非sql语句python3authorlizmdatetime2018020110:00:00coding:utf8'''
Easter79 Easter79
2年前
Twitter的分布式自增ID算法snowflake (Java版)
概述分布式系统中,有一些需要使用全局唯一ID的场景,这种时候为了防止ID冲突可以使用36位的UUID,但是UUID有一些缺点,首先他相对比较长,另外UUID一般是无序的。有些时候我们希望能使用一种简单一些的ID,并且希望ID能够按照时间有序生成。而twitter的snowflake解决了这种需求,最初Twitter把存储系统从MySQL迁移
Wesley13 Wesley13
2年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Wesley13 Wesley13
2年前
00:Java简单了解
浅谈Java之概述Java是SUN(StanfordUniversityNetwork),斯坦福大学网络公司)1995年推出的一门高级编程语言。Java是一种面向Internet的编程语言。随着Java技术在web方面的不断成熟,已经成为Web应用程序的首选开发语言。Java是简单易学,完全面向对象,安全可靠,与平台无关的编程语言。
Wesley13 Wesley13
2年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
6个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这