mybatis 配置 mysql连接池_spring 5.x 系列第5篇 —— 整合 mybatis + druid 连接池 (xml配置方式)...

项目目录结构

687217506024e353ea2de5883b9bc710.png

1. 导入依赖

创建 maven 工程,除了 Spring 的基本依赖外,还需要导入 Mybatis 和 Druid 的相关依赖:

org.springframeworkgroupId>

spring-jdbcartifactId>

${spring-base-version}version>

dependency>

mysqlgroupId>

mysql-connector-javaartifactId>

8.0.13version>

dependency>

com.oraclegroupId>

ojdbc6artifactId>

11.2.0.3.0version>

dependency>

org.mybatisgroupId>

mybatis-springartifactId>

1.3.2version>

dependency>

org.mybatisgroupId>

mybatisartifactId>

3.4.6version>

dependency>

com.alibabagroupId>

druidartifactId>

1.1.12version>

dependency>

2. web.xml 配置

在 web.xml 中配置 Spring 的前端控制器以及 Druid 的 Web 监控台,用于获取数据库的相关监控信息:

xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee

http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd"

version="3.1">

springMvcservlet-name>

org.springframework.web.servlet.DispatcherServletservlet-class>

contextConfigLocationparam-name>

classpath:springApplication.xmlparam-value>

init-param>

1load-on-startup>

servlet>

springMvcservlet-name>

/url-pattern>

servlet-mapping>

DruidStatViewservlet-name>

com.alibaba.druid.support.http.StatViewServletservlet-class>

resetEnableparam-name>

trueparam-value>

init-param>

loginUsernameparam-name>

druidparam-value>

init-param>

loginPasswordparam-name>

druidparam-value>

init-param>

servlet>

DruidStatViewservlet-name>

/druid/*url-pattern>

servlet-mapping>

DruidWebStatFilterfilter-name>

com.alibaba.druid.support.http.WebStatFilterfilter-class>

exclusionsparam-name>

*.js,*.gif,*.jpg,*.png,*.css,*.ico,/druid/*param-value>

init-param>

filter>

DruidWebStatFilterfilter-name>

/*url-pattern>

filter-mapping>

web-app>

3. 数据库配置

在 resources 文件夹下新建数据库配置文件 jdbc.properties:

# mysql 数据库配置

mysql.url=jdbc:mysql://localhost:3306/mysql

mysql.username=root

mysql.password=root

# oracle 数据库配置

oracle.url=jdbc:oracle:thin:@//IP 地址:端口号/数据库实例名

oracle.username=用户名

oracle.password=密码

4. Druid 连接池配置

在 resources 文件夹下创建 springApplication.xml 配置文件和 druid.xml 配置文件:

xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

xmlns:context="http://www.springframework.org/schema/context" xmlns:tx="http://www.springframework.org/schema/tx"

xmlns:mvc="http://www.springframework.org/schema/mvc"

xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd

http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.1.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx.xsd http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc.xsd">

bean>

bean>

class="org.springframework.jdbc.datasource.DataSourceTransactionManager">

bean>

beans>

xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

xmlns:context="http://www.springframework.org/schema/context"

xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd

http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.1.xsd">

bean>

beans>

5. MyBatis 配置

新建 mybtais 配置文件,按照需求配置额外参数, 更多 settings 配置项可以参考 官方文档

settings>

configuration>

6. 数据查询

新建查询接口及其实现类,以下示例分别查询的是 MySQL 和 Oracle 中的字典表:

public interface MysqlDao {

List get();

}

SELECT help_keyword_id AS id,name

FROM HELP_KEYWORD

WHERE HELP_KEYWORD_ID = #{id}

select>

mapper>

public interface OracleDao {

ListqueryById(long id);

}

select * from APEX_030200.WWV_FLOW_CALS where ID = #{id}

select>

mapper>

7. 测试查询

新建测试类进行测试:

@RestController

public class MysqlController {

@Autowired

private MysqlDao mysqlDao;

@GetMapping("relation/{id}")

public String get(@PathVariable(name = "id") String id) {

return mysqlDao.queryById(id).get(0).toString();

}

}

@RestController

public class OracleController {

@Autowired

private OracleDao oracleDao;

@GetMapping("flow/{id}")

public String get(@PathVariable(name = "id") Long id) {

return oracleDao.queryById(id).get(0).toString();

}

}

8. Druid 监控台

Druid Web 页面访问地址为:http://localhost:8080/druid/index.html ,可以登录后查看数据库相关监控数据:

e5c9bf12081a0409877c349c42db8f85.png

源码GitHub地址:https://github.com/heibaiying/spring-samples-for-all

8d5559fd3bf23d40e49ee8e0a73dcf96.png

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/429821.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

noi题库(noi.openjudge.cn) 1.8编程基础之多维数组T21——T25

T21 二维数组右上左下遍历 描述 给定一个row行col列的整数数组array,要求从array[0][0]元素开始,按从左上到右下的对角线顺序遍历整个数组。 输入 输入的第一行上有两个整数,依次为row和col。余下有row行,每行包含col个整数&#…

mysql memcache redis_redis,mysql,memcache的區別與比較,redis兩種數據存儲持久化方式

redis與mysql比較區別:mysql中一個中小型的網絡數據庫,比oracle和sqlserver小, 但是並發能力遠超過acess這樣的桌面數據庫;redis是一個內存鍵值數據庫,支持網絡、可基於內存亦可持久化的日志型、Key-Value數據庫。redi…

Java学习笔记三——数据类型

前言 Java是强类型(strongly typed)语言,强类型包含两方面的含义: 所有的变量必须先声明后使用;指定类型的变量只能接受预支匹配的值。这意味着每一个变量和表达式都有一个在编译时就确定的类型。 Java数据类型分为两大…

word可以直接导入mysql嘛_如何把word文档导入到数据库中——java POI

本文方法借鉴于https://www.cnblogs.com/ljysy/p/10574197.html在经过朋友的指导下,在处理文档的方式上有所不同。我的数据库使用的是SQL server,这篇博客将不介绍如何将数据存储进数据库中,只进行java POI处理文档数据的介绍,在处…

metinfo mysql off_利用Sqlmap测试MetInfo企业网站管理系统MySql注入

上次叉叉讲了Sqlmap简单注入(access数据库)教程,这次咱说说MySql数据库MetInfo,是一款强大的企业网站管理系统,采用PHPMysql架构。叉叉下载的是MetInfo 5.1.5的免费版本,咱不是大拿,不会分析源码,直接丢到W…

IOS的七种手势

今天为大家介绍一下IOS 的七种手势,手势在开发中经常用到,所以就简单 通俗易懂的说下, 话不多说,直接看代码: // 初始化一个UIimageViewUIImageView *imageView [[UIImageView alloc]initWithFrame:CGRectMake(100, 1…

mysql获取后一天_mysql获取当前时间,前一天,后一天

今天是2016年08月01日。date_sub(2016-08-01,interval 1 day) 表示 2016-07-31date_sub(2016-08-01,interval 0 day) 表示 2016-08-01date_sub(2016-08-01,interval -1 day) 表示 2016-08-02date_sub(curdate(),interval 1 day) 表示 2016-07-31date_sub(curdate(),interval -1…

c++获取sqlite3数据库表中所有字段的方法

常用方法: 1.使用sqlite3_get_table函数 2.获取sqlite创建表的sql语句字符串,然后进行解析获取到相应的字段 3.采用配置文件的方式,将所有字段名写入配置文件 方法1:使用sqlite3_get_table函数 代码: char *dbname “…

python sql语句生成_python Django 生成sql语句

class TestModel(models.Model):Namemodels.CharField(max_length64,blankTrue)>>> from django.core.management.color import no_style#Style是用来输出语句时着色的>>> from django.db import connection>>> from django.db.backends import cre…

Oozie的架构

Oozie的架构图,如下: 从oozie的架构图中,可以看到所有的任务都是通过oozie生成相应的任务客户端,并通过任务客户端来提交相应的任务。 继续。。。 转载于:https://www.cnblogs.com/zlslch/p/6117705.html

mysql如何做计划任务_简单的mysql 过程计划任务

首先讲讲过程是什么东西, 过程差不多就是SQL用的java之于方法.把一段sql做成过程后一个简单的调用就可以批量执行这些sql,很方便.其实就像java后台写个执行复杂sql的方法,你只是把这段sql存到数据库里了而已.mysql里面有"过程"和"函数"两个概念, 基本上前者…

Linux的#和$区别

【#】代表 root权限【$】代表普通用户 如果更改了/etc/profile , 或~/.bashrc等文档,可以用任何符号来代替它们。 linux窗口下的【rootlocate~】其中的【~】代表代表用户的家目录(root为/root,一般user则为/home/username)&#x…

python贴吧顶贴_python实现贴吧顶贴机器人

项目目录:– url.txt:多个需要顶起的帖子地址。– reply:多条随机回复的内容。–selenium:浏览器自动化测试框架。首先,我们先使用pip完成selenium的安装。接着,导入pyautogui自动控制鼠标的库。示例代码:p…

Confluence部署攻略 [转]

一、软件介绍 AtlassianConfluence(简称Confluence)是一个专业的wiki程序。它是一个知识管理的工具,通过它可以实现团队成员之间的协作和知识共享。Confluence不是一个开源软件,非商业用途可以免费使用。 Confluence使用简单&…

对自己的忠告

人生的路上有许许多多的十字路口,迷茫、孤独、失败在所难免,不管自己再怎么改变,也不要忘记那个我。对自己的忠告。 难是多做的理由,而不是不做的理由。当你以为看透事情的本质,或许你只不过是盒子中的盒子。一路上&am…

arp欺骗技术

ARP欺骗技术-获取内网目标IP访问图片!简介:ARP(Address Resolution Protocol,地址解析协议)是一个位于TCP/IP协议栈中的网络层,负责将某个IP地址解析成对应的MAC地址。要求: 虚拟机 Kali linux系统 1--命令…

java 读取project_java project 和 java web project 获取路径问题

java project中如何获得相对路径(编译后的目录是在/bin目录下)(一般图片 这些目录放在 项目目录下,与src同级)在static方法中,用String path Test.class.getResource("").getPath();在非static方法中,用String path this.getClas…

前端插件介绍

1.JQuery EasyUI http://www.jeasyui.net/demo/380.html,各种示例代码可以修改使用,简化开发流程。 http://www.jeasyui.net/download/,下载后能查看各种html的源码,引入它的css、js、jquery,然后拿过来demo里的代码就…

java报错 日志_java 日志报错

SLF4J: Failed to load class "org.slf4j.impl.StaticLoggerBinder".SLF4J: Defaulting to no-operation (NOP) logger implementationSLF4J: See http://www.slf4j.org/codes.html#StaticLoggerBinder for further details.一月 30, 2021 9:13:10 下午 com.github.u…

存储过程实现可扩展灵活接口

序言 本文分享一个通过数据库(ORACLE)的存储过程,遵循“对修改封闭,对增加开放”的开闭原则,实现的可扩展性极强的灵活接口方案。 背景 本人从事离散型MES系统的开发工作,近期负责了一个PCBA(电…