必发365bifa0000Spring MVC整合Mybatis 入门

by admin on 2019年4月13日

除此以外,还有配备文件目录。在
src/main/resources目录下,新建mapper文件夹,与 src/main/java/mapper
对应:一个RoleMapper.java 对应着四个RoleMapper.xml配置文件,再添加相应的Spring配置就足以兑现数据库的操作。在
src/main/resources目录下,新建spring文件夹,里面有八个布局文件:spring-web.xml是web相关配置;spring-dao.xml是数据库相关的安顿;spring-service.xml是Service类相关的安排。当然也可以将有着的配置放在一个文书里,比如大规模的applicationContext.xml,分开配置来说,可能看起来更分明。大概目录结构如下:

中夏族世界观的变化 

最后,还索要运行web应用程序,在
pom.xml中安插 jetty 容器,来运作web应用:

1篇很好的稿子,原著地址:http://bbs.tianya.cn/post-worldlook-1776358-1.shtml

 

  凡日月所照、江河所至,皆为汉土。 

必发365bifa0000,打开Intellij,File–>new
Project—>选中,Maven—>勾上”Create from archetype”—>选择
Maven web project。如下图:


接下来大家又在spring-dao.xml中布置了拜访数据库:详细具体说明如下:

 

必发365bifa0000 1

  在史记《伍帝本纪》中有姬俊“日月所照,风雨所至,莫不从服。”

 

 

 

————-回帖————-

View Code

 

那全部到底是什么收获的吧?

  汉宣定胡碑在《唐宋书。南匈奴列传》中国建工业总会公司武二10八年班彪(汉书笔者班固,班昭,主力班仲升的生父)给光武帝的奏疏中有“汉秉威信,总率万国,日月所照,皆为臣妾。” 

再来看事情逻辑,很简单:用户从浏览器中发一个询问请求
Role,请求的参数为 id,瑟维斯根据 id 去数据库找 Role 记录,重回给用户
id 对应的Role。

第12行,@Service以Spring注明的方法将RoleServiceImpl定义成Bean,在spring-service.xml中配备:component-scan,让Spring去扫描
service包下带有表明的类,告诉Spring容器 RoleService(Impl)类
是一个Bean对象。在其余类中就能够用 @Autowired
将RoleService注入。

  蜀国中华夏族的宇宙观是什么的啊?中华人民共和国人有部族概念也有国家概念,但是对土地却从不什么概念。为什么如此?因为实力,你没看错。因为实力。中华夏族民共和国人对土地的概念分成二种,一种是自个儿爱上的,另壹种是本身看不上的。仅此而已。中夏族民共和国人以为中华夏族民共和国是怎么着?中国是大旨之国放在人间大地之中,是世界上最肥妹丰厚的土地。而中夏族民共和国人又是何许?是神的子女。大家的当局是什么?是天朝,负责管理整个人间。而中中原人民共和国人具有的是哪些?是中夏族民共和国的土地么?不是,中国人,中中原人民共和国的统治者拥有的是天底下,是总体人间。问苍茫大地哪个人主沉浮,你就明白了中华人心里把自个儿有多当回事了。 

全部的spring-dao.xml配置文件:

   
而这般的人生观又是怎么时候发现变化的吗?是鸦片战争。中夏族民共和国民党统治治者认为在此场战争中最大的损失,不是割让了九龙,而是承认United Kingdom是一独立国家,2个不要低头天朝的独立国家。英帝国民党统治治者也在中华的叫做中上了皇号,不再称英女帝,改称英女王。成了和中华统治者平起平坐的皇,人间的另1个统治者。中华夏族民共和国人的天下观崩溃了,取而代之的是两元世界观。就是世界上有两国,2个叫做中国,另一个叫外国。就算到了明日,中华夏族民共和国人也1如既往是那种思想。凡提中中原人民共和国,必提海外。什么产业,什么科学和技术海外当先,海外先进。从不提到底是哪国超过哪国先进,反正都是异域。国外有的,中华夏族民共和国亟要求有。什么科学商量装备,定位系统,空间站,结算系统,贸易连串。国外有的,笔者也得有一套。笔者任由你究竟是有点国家凑齐搞的1套,反正作者得有一套。什么样的事物,只要海外有别的二个国家比中夏族民共和国好,那中国就输了。什么东西的占有没超越总量的5/十,中国又输了,又输给国外了,好落后啊。超越一半占用,好爽好爽,那才是以此世界应该有个别样子。西班牙人都不清楚中国人,认为中华夏族民共和国人怎么那样拼?你们已经在许多上边很理想很理想了。已经远非其余四个国家能够独立和华夏圆满的相相比较量,为何还这么拼?因为中中原人民共和国人要的不是把何人,把哪些国家比下去。中中原人民共和国人是要在有着的领域把拥有的国度统统比下去,中中原人民共和国要赢的不是哪些国家,而是要赢中国人眼中的异域,只有那样,才能对得起中夏族民共和国,大旨之国的称谓。中中原人民共和国人不爱笑,因为自身扛起的负担太重,中中原人民共和国人活的累啊。中华人民共和国人要的不单是钱,中中原人民共和国人要的是神州人的1整套人间秩序。作者国家仁恩浩荡,恭顺者无困不援;义武奋扬,跳梁者虽强必戳。

对应的RoleMapper.xml配置如下:

   
那干什么中夏族民共和国的山河并不曾变的最为大?因为看不上喽。三保太监一次出国也没找到一块大旨王朝看的上的土地,最终得出的定论就是大地富庶之地决定尽归天朝。对于看不上的土地常常就封个2字郡王,你协调玩耍吧,记得按时汇报工作。而对此看的上的土地,那是一块也不可能放过,就像越南社会主义共和国红河平原多少年来几经易手,只要中原的王朝统一强盛,非拿回去不可,起码也要臣服于天朝,遵循管理。不服就打。中夏族民共和国人心中最要紧的不是土地,而是随处臣服,只要臣服于天朝,土地还真不算怎么严重的难点。送你个白龙尾,划半个长汉中都不是题材,只是你遵守天朝,依然中外的一片段。而天下是朕的。 

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:context="http://www.springframework.org/schema/context"
       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.xsd
    http://www.springframework.org/schema/mvc
    http://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd">
    <mvc:annotation-driven />

    <mvc:default-servlet-handler/>

    <!-- 3.配置jsp 显示ViewResolver -->
    <!--<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">-->
        <!--<property name="viewClass" value="org.springframework.web.servlet.view.JstlView" />-->
        <!--<property name="prefix" value="/WEB-INF/jsp/" />-->
        <!--<property name="suffix" value=".jsp" />-->
    <!--</bean>-->

    <!-- 4.扫描web相关的bean -->
    <context:component-scan base-package="controller" />
</beans>

抑或应用 TestNg等测试工具进行测试。

 1 package controller;
 2 
 3 import org.springframework.beans.factory.annotation.Autowired;
 4 import org.springframework.stereotype.Controller;
 5 import org.springframework.web.bind.annotation.RequestMapping;
 6 import org.springframework.web.bind.annotation.RequestParam;
 7 import org.springframework.web.bind.annotation.ResponseBody;
 8 import pojo.Role;
 9 import service.RoleService;
10 
11 /**
12  * Created by Administrator on 2017/8/10.
13  */
14 @Controller
15 public class RoleController {
16     @Autowired
17     private RoleService roleService;
18 
19     @RequestMapping("/role/getRole")
20     @ResponseBody public Role getRole(@RequestParam("id") long id)
21     {
22         long start = System.currentTimeMillis();
23         Role role = roleService.getRole(id);
24         long end = System.currentTimeMillis();
25         System.out.println(end-start);
26         return role;
27     }
28 }

1玖行,在web.xml中布局了
servlet-mapping,当浏览器请求的U大切诺基L带有”role/getRole”时,就会阻碍请求将给
RoleController来处理。

    <!-- 2.数据库连接池 -->
    <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
        <!-- 配置连接池属性 -->
        <property name="driverClass" value="${jdbc.driver}"/>
        <property name="jdbcUrl" value="${jdbc.url}"/>
        <property name="user" value="${jdbc.username}"/>
        <property name="password" value="${jdbc.password}"/>

        <!-- c3p0连接池的私有属性 -->
        <property name="maxPoolSize" value="30"/>
        <property name="minPoolSize" value="10"/>
        <!-- 关闭连接后不自动commit -->
        <property name="autoCommitOnClose" value="false"/>
        <!-- 获取连接超时时间 -->
        <property name="checkoutTimeout" value="10000"/>
        <!-- 当获取连接失败重试次数 -->
        <property name="acquireRetryAttempts" value="2"/>
    </bean>

一步步Next,等待工程Build成功,假使右下角有提醒“Maven
project need to be imported“则点击: import change…”

后边介绍的都是Spring应用上下文,而那边的
HTTP请求牵涉到
web应用上下文,2者是什么样整合的吧?在web.xml中进行配置:

 

select id,role_name as roleName, note from t_role where id = #{id}

由此,那也是怎么
大家只供给经过Spring将RoleMapper能够访问数据库的原委。而当
Service要求拜访数据库时,只须求将RoleMapper注入进来,就足以实施getRole方法查询数据库了。

View Code

必发365bifa0000 2必发365bifa0000 3

速龙liJ IDEA 创设 hello world Java web
Maven项目从头到尾都有图有实质2017版本

必发365bifa0000 4

20行,@ResponseBody定义了
处理以往的再次回到值,将 Role 对象以
JSON格式封装起来,再次来到给浏览器。@RequestParam(“id”),定义请求参数。

譬如在浏览器中输入:http://localhost:8000/mvc/role/getRole?id=5

必发365bifa0000 5必发365bifa0000 6

 

RoleService.java代码如下:

必发365bifa0000 7

在src.main下新建二个文书夹
java, 作为源代码目录。CTPAJEROL+ALT+SHIFT+S 打开“project
structure配置窗口”,将 java 目录关联成 source目录。

package service;

import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import pojo.Role;

/**
 * Created by Administrator on 2017/8/12.
 */
public class RoleServiceImplTest {
    public static void main(String[] args) {
        ApplicationContext applicationContext = new ClassPathXmlApplicationContext("classpath:spring/spring-service.xml");
        RoleService roleService = (RoleService) applicationContext.getBean(RoleService.class);
        Role role = roleService.getRole(5);
        System.out.println(role);
    }
}
<!-- jetty插件 -->
      <plugin>
        <groupId>org.mortbay.jetty</groupId>
        <artifactId>maven-jetty-plugin</artifactId>
        <version>6.1.25</version>
        <configuration>
          <connectors>
            <connector implementation="org.mortbay.jetty.nio.SelectChannelConnector">
              <port>8000</port>
              <maxIdleTime>60000</maxIdleTime>
            </connector>
          </connectors>
          <contextPath>/mvc</contextPath>
          <scanIntervalSeconds>0</scanIntervalSeconds>
        </configuration>
      </plugin>

pom.xml配置文件

    <!-- 4.配置扫描Dao接口包,动态实现Dao接口,注入到spring容器中 -->
    <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
        <!-- 注入sqlSessionFactory -->
        <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"/>
        <!-- 给出需要扫描mapper接口包 -->
        <property name="basePackage" value="mapper"/>
    </bean>

1肆行,@Controller
以Spring表明的法子将
RoleController类定义为Spring容器可管制的Bean。

连接池的依靠包,又在哪里吗?因为大家采取的是Maven
POM管理注重,在pom.xml文件中就须要配备:

 

必发365bifa0000 8

 

 

View Code

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">

<mapper namespace="mapper.RoleMapper">
    <select id="getRole" parameterType="long" resultType="Role">
        select id,
        role_name as roleName, note from t_role where id = #{id}
    </select>
</mapper>
package mapper;
import org.springframework.stereotype.Repository;
import pojo.Role;
@Repository
public interface RoleMapper {
    public Role getRole(long id);
}

配置数据库连接消息:访问哪个数据库?数据库地址在哪?访问数据库的端口是什么?用户名和密码是怎么样?那几个音信都在jdbc.properties文件中定义好了,<context:property-placeholder>告诉Spring容器去何地读取jdbc.properties配置文件。jdbc.properties文件如下:

必发365bifa0000 9必发365bifa0000 10

 

2为啥Spring容器知道
将 RoleService 作为三个Bean注入到 RoleController中去吧?

RoleController.java代码如下:

 

姣好之后,整个项目Build
Success,会变卦如下初叶目录:

 

    <dependency>
      <groupId>org.mybatis</groupId>
      <artifactId>mybatis-spring</artifactId>
      <version>1.3.0</version>
    </dependency>
    <dependency>
      <groupId>org.mybatis</groupId>
      <artifactId>mybatis</artifactId>
      <version>3.4.0</version>
    </dependency>

接下去再把SqlSession
告诉RoleMapper对象,让它拿着SqlSession去操作数据库。

jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/test
jdbc.username=root
jdbc.password=xxxxx

service,业务逻辑实现类。瑟维斯一般都需求DAO类(或然说Mapper类)操作数据库,然后成功相应的业务逻辑处理。

spring-web.xml

 

 1 package service.impl;
 2 
 3 import mapper.RoleMapper;
 4 import org.springframework.beans.factory.annotation.Autowired;
 5 import org.springframework.stereotype.Service;
 6 import pojo.Role;
 7 import service.RoleService;
 8 
 9 /**
10  * Created by Administrator on 2017/8/10.
11  */
12 @Service
13 public class RoleServiceImpl implements RoleService {
14 
15     @Autowired
16     private RoleMapper roleMapper;
17 
18     public Role getRole(long id){
19         Role role = roleMapper.getRole(id);
20         return role;
21     }
22 }

pojo,实体类。对应数据库中的表,1般pojo类中的各样属性对应数据库中的一个字段。

    <dependency>
      <groupId>mysql</groupId>
      <artifactId>mysql-connector-java</artifactId>
      <version>5.1.37</version>
      <scope>runtime</scope>
    </dependency>
    <dependency>
      <groupId>c3p0</groupId>
      <artifactId>c3p0</artifactId>
      <version>0.9.1.2</version>
    </dependency>

必发365bifa0000 11

三怎么
roleSevice.getRole(id)就能从数据库中摸索相应的记录并赶回吗?后面包车型的士RoleMapper.java
和 RoleMapper.xml配置文件已经定义好了操作数据库的言辞:

controller,控制器类。DispatcherServlet将堵住到的HTTP请求提交对应的Controller来处理,Controller调用
Service 达成相应的乞请职责。

 

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
  <modelVersion>4.0.0</modelVersion>
  <groupId>mymvc</groupId>
  <artifactId>mymvc</artifactId>
  <packaging>war</packaging>
  <version>1.0-SNAPSHOT</version>
  <name>mymvc Maven Webapp</name>
  <url>http://maven.apache.org</url>
  <dependencies>
    <dependency>
      <groupId>junit</groupId>
      <artifactId>junit</artifactId>
      <version>3.8.1</version>
      <scope>test</scope>
    </dependency>
    <!-- 2.数据库 -->
    <dependency>
      <groupId>mysql</groupId>
      <artifactId>mysql-connector-java</artifactId>
      <version>5.1.37</version>
      <scope>runtime</scope>
    </dependency>
    <dependency>
      <groupId>c3p0</groupId>
      <artifactId>c3p0</artifactId>
      <version>0.9.1.2</version>
    </dependency>

    <dependency>
      <groupId>org.mybatis</groupId>
      <artifactId>mybatis-spring</artifactId>
      <version>1.3.0</version>
    </dependency>
    <dependency>
      <groupId>org.mybatis</groupId>
      <artifactId>mybatis</artifactId>
      <version>3.4.0</version>
    </dependency>

    <!-- 3.Servlet web -->
    <dependency>
      <groupId>taglibs</groupId>
      <artifactId>standard</artifactId>
      <version>1.1.2</version>
    </dependency>
    <dependency>
      <groupId>jstl</groupId>
      <artifactId>jstl</artifactId>
      <version>1.2</version>
    </dependency>
    <dependency>
      <groupId>com.fasterxml.jackson.core</groupId>
      <artifactId>jackson-databind</artifactId>
      <version>2.5.4</version>
    </dependency>
    <dependency>
      <groupId>javax.servlet</groupId>
      <artifactId>javax.servlet-api</artifactId>
      <version>3.1.0</version>
    </dependency>

    <!-- 4.Spring -->
    <!-- 1)Spring核心 -->
    <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-core</artifactId>
      <version>4.2.2.RELEASE</version>
    </dependency>
    <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-beans</artifactId>
      <version>4.2.2.RELEASE</version>
    </dependency>
    <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-context</artifactId>
      <version>4.2.2.RELEASE</version>
    </dependency>

    <!-- 2)Spring DAO层 -->
    <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-jdbc</artifactId>
      <version>4.2.2.RELEASE</version>
    </dependency>
    <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-tx</artifactId>
      <version>4.2.2.RELEASE</version>
    </dependency>

    <!-- 3)Spring web -->
    <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-web</artifactId>
      <version>4.2.2.RELEASE</version>
    </dependency>
    <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-webmvc</artifactId>
      <version>4.2.2.RELEASE</version>
    </dependency>

    <!-- 4)Spring test -->
    <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-test</artifactId>
      <version>4.2.2.RELEASE</version>
    </dependency>
    <dependency>
      <groupId>org.testng</groupId>
      <artifactId>testng</artifactId>
      <version>6.8.7</version>
      <scope>test</scope>
    </dependency>

    <dependency>
      <groupId>org.mortbay.jetty</groupId>
      <artifactId>jsp-2.1</artifactId>
      <version>6.0.0</version>
    </dependency>
  </dependencies>
  <build>

    <finalName>mymvc</finalName>
    <plugins>
      <!-- jetty插件 -->
      <plugin>
        <groupId>org.mortbay.jetty</groupId>
        <artifactId>maven-jetty-plugin</artifactId>
        <version>6.1.25</version>
        <configuration>
          <connectors>
            <connector implementation="org.mortbay.jetty.nio.SelectChannelConnector">
              <port>8000</port>
              <maxIdleTime>60000</maxIdleTime>
            </connector>
          </connectors>
          <contextPath>/mvc</contextPath>
          <scanIntervalSeconds>0</scanIntervalSeconds>
        </configuration>
      </plugin>
    </plugins>
  </build>
</project>

必发365bifa0000 12必发365bifa0000 13

 

 <servlet>
    <servlet-name>mvc</servlet-name>
    <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
    <!-- 配置springMVC需要加载的配置文件
        spring-dao.xml,spring-service.xml,spring-web.xml
        Mybatis - > spring -> springmvc
     -->
    <init-param>
      <param-name>contextConfigLocation</param-name>
      <param-value>classpath:spring/spring-*.xml</param-value>
    </init-param>
  </servlet>
package service;
import pojo.Role;
/**
 * Created by Administrator on 2017/8/10.
 */
public interface RoleService {
    public Role getRole(long id);
}

知道了数据库在哪个地方了,以何种措施连接数据库呢?一般会安插各类连接池

POJO类
Role.java代码和数据库表t_role字段,参考那篇小说尾部。RoleMapper.java
定义了操作数据库的章程–根据 id字段 来查找
Role,getRole方法同盟RoleMapper.xml中定义的数据库操作语句,就能够由Mybatis框架来顶住全体的数据库操作事宜了。代码如下:

附完整的:mybatisConfig.xml
 

View Code

必发365bifa0000 14

数据库中记录如下:

必发365bifa0000 15必发365bifa0000 16

mapper,数据库操作类。定义了有的哪些操作数据库的章程。

因为,RoleService类使用
了@瑟维斯 注明,并且在spring-service.xml中配置
了<component-scan….> 见上边RoleService源代码部分。

<context:component-scan base-package="mapper"/>

View Code

现实的贯彻类如下:

 

 <context:property-placeholder location="classpath:jdbc.properties"/>


java 目录下创办多少个子目录 controller、mapper、pojo、service

必发365bifa0000 17

提倡呼吁—>请求拦截—>再次来到请求
是何许落实的吧?在web.xml中陈设了servlet-mapping,当中的<servlet-name>mvc</servlet-name>那也是呼吁U凯雷德L中 有
mvc
前缀的来由。<url-pattern>将优秀的乞请提交DispatcherServlet,由DispatcherServlet转发给相应的
Controller,在RoleController.java中选用 @RequestMapping配置了
请求的途径role/getRole,这样
http://localhost:8000/mvc/*role/getRole*?id=5
 就会提交RoleController来处理了。

    <!-- 扫描service包下所有使用注解的类型 -->
    <context:component-scan base-package="service" />

本文记录使用速龙lij成立Maven
Web工程搭建Spring MVC + Mybatis
的3个格外简单的言传身教。关于Mybatis的入门使用可参看那篇文章,本文在该文的基本功上,引进了Spring
MVC作用。首先是创造项目:

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       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"
       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.xsd
    http://www.springframework.org/schema/tx
    http://www.springframework.org/schema/tx/spring-tx.xsd">
    <!-- 扫描service包下所有使用注解的类型 -->
    <context:component-scan base-package="service" />
    <import resource="spring-dao.xml"/>
    <!-- 配置事务管理器 -->
    <bean id="transactionManager"
          class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
        <!-- 注入数据库连接池 -->
        <property name="dataSource" ref="dataSource" />
    </bean>

    <!-- 配置基于注解的声明式事务 -->
    <tx:annotation-driven transaction-manager="transactionManager" />
</beans>
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
        PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
    <!-- 配置全局属性 -->
    <settings>
        <!-- 使用jdbc的getGeneratedKeys获取数据库自增主键值 -->
        <setting name="useGeneratedKeys" value="true" />

        <!-- 使用列别名替换列名 默认:true -->
        <setting name="useColumnLabel" value="true" />

        <!-- 开启驼峰命名转换:Table{create_time} -> Entity{createTime} -->
        <setting name="mapUnderscoreToCamelCase" value="true" />
    </settings>
</configuration>

布局好了拜访数据库的条件,还亟需拜访数据库的有血有肉实例,那正是SqlSession。于是三番五次在spring-dao.xml添加配置:

 

    <!-- 3.配置SqlSessionFactory对象 -->
    <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
        <!-- 注入数据库连接池 -->
        <property name="dataSource" ref="dataSource"/>
        <!-- 配置MyBaties全局配置文件:mybatisConfig.xml -->
        <property name="configLocation" value="classpath:mybatisConfig.xml"/>
        <!-- 扫描entity包 使用别名 -->
        <property name="typeAliasesPackage" value="pojo"/>
        <!-- 扫描sql配置文件:mapper需要的xml文件 -->
        <property name="mapperLocations" value="classpath:mapper/*.xml"/>
    </bean>

 

参考文献:

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/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.xsd">

    <context:component-scan base-package="mapper"/>
    <!-- 配置整合mybatis过程 -->
    <!-- 1.配置数据库相关参数properties的属性:${url} -->

    <context:property-placeholder location="classpath:jdbc.properties"/>

    <!-- 2.数据库连接池 -->
    <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
        <!-- 配置连接池属性 -->
        <property name="driverClass" value="${jdbc.driver}"/>
        <property name="jdbcUrl" value="${jdbc.url}"/>
        <property name="user" value="${jdbc.username}"/>
        <property name="password" value="${jdbc.password}"/>

        <!-- c3p0连接池的私有属性 -->
        <property name="maxPoolSize" value="30"/>
        <property name="minPoolSize" value="10"/>
        <!-- 关闭连接后不自动commit -->
        <property name="autoCommitOnClose" value="false"/>
        <!-- 获取连接超时时间 -->
        <property name="checkoutTimeout" value="10000"/>
        <!-- 当获取连接失败重试次数 -->
        <property name="acquireRetryAttempts" value="2"/>
    </bean>

    <!-- 3.配置SqlSessionFactory对象 -->
    <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
        <!-- 注入数据库连接池 -->
        <property name="dataSource" ref="dataSource"/>
        <!-- 配置MyBaties全局配置文件:mybatisConfig.xml -->
        <property name="configLocation" value="classpath:mybatisConfig.xml"/>
        <!-- 扫描entity包 使用别名 -->
        <property name="typeAliasesPackage" value="pojo"/>
        <!-- 扫描sql配置文件:mapper需要的xml文件 -->
        <property name="mapperLocations" value="classpath:mapper/*.xml"/>
    </bean>

    <!-- 4.配置扫描Dao接口包,动态实现Dao接口,注入到spring容器中 -->
    <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
        <!-- 注入sqlSessionFactory -->
        <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"/>
        <!-- 给出需要扫描Dao接口包 -->
        <property name="basePackage" value="mapper"/>
    </bean>
</beans>

譬如,对RoleService举行测试如下:

透过contextConfigLocation将
spring上下文中的配置文件加载进来,完结双方的整合。

报告Spring容器扫描mapper目录下的
带注脚的类,那样RoleService就可以活动注入
RoleMapper对象了,有了RoleMapper对象,通过Mybatis框架,就能够访问数据库了。而Spring与Mybatis的整合依赖包,就须要在pom.xml中提交:

在src目录下,新建 test
文件夹,用来作测试目录。然后在test目录下,建多少个java目录,并将该目录关联为
“测试目录”。然后,在java目录下,src/main/java 一 壹对应的文件夹,作为mapper、controller、service类的测试类存放的文书夹。

就足以在IDEA左侧,maven
project中点击 jetty run 来运作了。

 

壹RoleController供给2个RoleService对象,然后在第二三行调用
getRole方法,重临2个Role对象。首先第二6-一七行,使用 @Autowired将
RoleService注入到RoleController中,那样RoleController不需求显示地new
RoleService对象,对应的创制进度由Spring容器自动达成—-对象的创导 与
“对象的行使”
解耦。“对象的接纳其实便是工作逻辑,让开发者不需求关怀对象的创始了”

 

完全spring-sevice.xml配置文件:

RoleService的调试:

必发365bifa0000 18

 

发表评论

电子邮件地址不会被公开。 必填项已用*标注

网站地图xml地图