框架篇:Spring+SpringMVC+Mybatis整合開發


 

前言:

  前面我已搭建過ssh框架(http://www.cnblogs.com/xrog/p/6359706.html)。

  然而mybatis表示不服啊。 Hibernate:“不服便戰!”

  我們先看下對戰雙方陣勢:

                Hiberate    VS  Mybatis

   第一回合:開發速度

      刷圖難度:Hibernate前期升級需要大量經驗,所以你想玩轉Hibernate,得多打打小怪,看看攻略什么的.

           Mybatis相對簡單許多,只要MySQL這件裝備強化上去,刷怪輕輕松松

      刷圖效率:Mybatis需要我們手動寫sql語句,回歸最原始的方式,所以可以按需求制定查詢的字段,

              提高效率,由於是自己編寫sql語句,所以查詢的靈活度也比hibernate高。

           Hibernate的查詢會將表中的所有字段查詢出來,這一點性能消耗比Mybatis大。當然,

              Hibernate也可以自己寫SQL來指定需要查詢的字段,但這樣就破壞了Hibernate封裝

              以及開發的簡潔性。

   第二回合:數據庫移植性

      Mybatis由於所有SQL都是依賴數據庫書寫的,所以擴展性,遷移性比較差。

      Hibernate與數據庫具體的關聯都在XML中,所以HQL對具體是用什么數據庫並不是很關心。

 

   第三回合:緩存機制對比

      相同點:Hibernate和Mybatis的二級緩存除了采用系統默認的緩存機制外,都可以通過實現你自己的緩存或為

          其他第三方緩存方案,創建適配器來完全覆蓋緩存行為。

      不同點:Hibernate的二級緩存配置在SessionFactory生成的配置文件中進行詳細配置,

            然后再在具體的表-對象映射中配置是那種緩存。

          MyBatis的二級緩存配置都是在每個具體的表-對象映射中進行詳細配置,這樣針對不同的表可以自定義

            不同的緩存機制。並且Mybatis可以在命名空間中共享相同的緩存配置和實例,通過Cache-ref來實現。  

      兩者比較:因為Hibernate對查詢對象有着良好的管理機制,用戶無需關心SQL。所以在使用二級緩存時如果出現臟數據,

           系統會報出錯誤並提示。而MyBatis在這一方面,使用二級緩存時需要特別小心。如果不能完全確定數據更新

           操作的波及范圍,避免Cache的盲目使用。否則,臟數據的出現會給系統的正常運行帶來很大的隱患。

 

 

    總結:    

      Mybatis:小巧、方便、高效、簡單、直接、半自動化

      Hibernate:強大、方便、高效、復雜、間接、全自動化

 

好了,沒時間解釋了,快上車

導包

還是老套路,就不多說了,配置pom.xml: 

<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>XRom</groupId>
    <artifactId>ssm</artifactId>
    <packaging>war</packaging>
    <version>1.0-SNAPSHOT</version>
    <name>ssm Maven Webapp</name>
    <url>http://maven.apache.org</url>

    <!--此處統一配置版本信息-->
    <properties>
        <!-- spring版本 -->
        <springVersion>4.3.1.RELEASE</springVersion>
        <!-- mybatis版本 -->
        <mybatis.version>3.2.6</mybatis.version>
        <!--<mysqlVersion>6.0.3</mysqlVersion>-->
        <mysqlVersion>5.1.38</mysqlVersion>

        <lombokVersion>1.16.10</lombokVersion>
        <log4jVersion>1.2.17</log4jVersion>
        <slf4jVersion>1.7.7</slf4jVersion>
        <fileuploadVersion>1.3.1</fileuploadVersion>
        <jstlVersion>1.2</jstlVersion>
        <!--<taglibVersion>1.1.2</taglibVersion>-->
        <!--<servletVersion>3.0-alpha-1</servletVersion>-->
    </properties>

    <dependencies>
        <dependency>
          <groupId>junit</groupId>
          <artifactId>junit</artifactId>
          <version>3.8.1</version>
          <scope>test</scope>
        </dependency>

        <!-- spring-->
        <dependency>
          <groupId>org.springframework</groupId>
          <artifactId>spring-beans</artifactId>
          <version>${springVersion}</version>
        </dependency>

        <dependency>
          <groupId>org.springframework</groupId>
          <artifactId>spring-core</artifactId>
          <version>${springVersion}</version>
        </dependency>

        <dependency>
          <groupId>org.springframework</groupId>
          <artifactId>spring-context</artifactId>
          <version>${springVersion}</version>
        </dependency>
        <dependency>
          <groupId>org.springframework</groupId>
          <artifactId>spring-orm</artifactId>
          <version>${springVersion}</version>
        </dependency>

        <!-- spring web + spring MVC-->
        <dependency>
          <groupId>org.springframework</groupId>
          <artifactId>spring-web</artifactId>
          <version>${springVersion}</version>
        </dependency>
        <dependency>
          <groupId>org.springframework</groupId>
          <artifactId>spring-webmvc</artifactId>
          <version>${springVersion}</version>
        </dependency>

        <!-- mybatis核心包 -->
        <dependency>
          <groupId>org.mybatis</groupId>
          <artifactId>mybatis</artifactId>
          <version>${mybatis.version}</version>
        </dependency>
        <!-- mybatis + spring -->
        <dependency>
          <groupId>org.mybatis</groupId>
          <artifactId>mybatis-spring</artifactId>
          <version>1.2.2</version>
        </dependency>


        <!-- DataBase數據庫連接 mysql包-->
        <dependency>
          <groupId>mysql</groupId>
          <artifactId>mysql-connector-java</artifactId>
          <version>${mysqlVersion}</version>
        </dependency>

        <!-- 導入dbcp的jar包,用來在applicationContext.xml中配置數據庫 -->
        <dependency>
          <groupId>commons-dbcp</groupId>
          <artifactId>commons-dbcp</artifactId>
          <version>1.2.2</version>
        </dependency>

        <!-- log4j配置, 視情況添加-->
        <dependency>
            <groupId>log4j</groupId>
            <artifactId>log4j</artifactId>
            <version>${log4jVersion}</version>
        </dependency>
        <!--<dependency>-->
            <!--<groupId>com.alibaba</groupId>-->
            <!--<artifactId>fastjson</artifactId>-->
            <!--<version>1.1.41</version>-->
        <!--</dependency>-->
        <dependency>
            <groupId>org.slf4j</groupId>
            <artifactId>slf4j-api</artifactId>
            <version>${slf4jVersion}</version>
        </dependency>
        <dependency>
            <groupId>org.slf4j</groupId>
            <artifactId>slf4j-log4j12</artifactId>
            <version>${slf4jVersion}</version>
        </dependency>

        <!--文件上傳包-->
        <dependency>
          <groupId>commons-fileupload</groupId>
          <artifactId>commons-fileupload</artifactId>
          <version>${fileuploadVersion}</version>
        </dependency>

        <!-- jsp頁面使用的jstl支持-->
        <dependency>
          <groupId>jstl</groupId>
          <artifactId>jstl</artifactId>
          <version>${jstlVersion}</version>
        </dependency>

        <!-- lombok插件導包-->
        <dependency>
          <groupId>org.projectlombok</groupId>
          <artifactId>lombok</artifactId>
          <version>${lombokVersion}</version>
          <scope>provided</scope>
        </dependency>
    </dependencies>


    <build>
        <finalName>ssm</finalName>

        <plugins>
            <!--java8-->
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-compiler-plugin</artifactId>
                <configuration>
                    <source>1.8</source>
                    <target>1.8</target>
                </configuration>
            </plugin>

            <!-- mybatis-generator-maven-plugin-->
            <plugin>
                <groupId>org.mybatis.generator</groupId>
                <artifactId>mybatis-generator-maven-plugin</artifactId>
                <version>1.3.2</version>
                <configuration>
                    <verbose>true</verbose>
                    <overwrite>true</overwrite>
                </configuration>
            </plugin>

        </plugins>
    </build>
</project>

 

  

OK,配置后運行下maven,就會自動向中央倉庫下載相應的包啦!另外我這里結尾多配置了兩個插件,一個是Java8新特性的,一個是Mybatis Generator的,這兩個插件暫時可以不配置 

 

SpringMVC配置

我現在在這里把我配置后的結構拿出來給你們看下,最終的結構就是這樣了,當然,部分配置如log4j,generator這些本文章並沒用使用到

 

 

我們先配置下SpringMVC的配置:resources/META-INF/spring-mvc.xml

 ps:這個和上篇博客配置是一樣的

<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-4.1.xsd
        http://www.springframework.org/schema/context
        http://www.springframework.org/schema/context/spring-context-4.1.xsd
        http://www.springframework.org/schema/mvc
        http://www.springframework.org/schema/mvc/spring-mvc-4.1.xsd">
       
       <!-- 啟動注解驅動的spring MVC功能,注冊請求url和注解POJO類方法的映射-->
       <mvc:annotation-driven />
    <!-- 對模型視圖名稱的解析,在請求時模型視圖名稱添加前后綴 -->
    <context:component-scan base-package="com.ssm" />

    <bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
        <property name="viewClass" value="org.springframework.web.servlet.view.JstlView" />
        <property name="prefix" value="views/" />      <!-- 前綴 -->
        <property name="suffix" value=".jsp" />   <!-- 后綴 -->
    </bean>
    
    <!--這里是對靜態資源的映射-->
    <mvc:resources mapping="/js/**" location="/resources/js/" />
    <mvc:resources mapping="/css/**" location="/resources/css/" />
    <mvc:resources mapping="/img/**" location="/resources/img/" />

</beans>

 

 好了,我們現在修改下web.xml這個配置文件,完善下SpringMVC的配置, web.xml配置如下:

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xmlns="http://java.sun.com/xml/ns/javaee"
         xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
         version="3.0">
        <!-- 地址為http://localhost:8080/  顯示的默認網頁-->
        <welcome-file-list>
          <welcome-file>/index.jsp</welcome-file>
        </welcome-file-list>

        <!-- spring MVC config start-->
        <servlet>
            <servlet-name>spring</servlet-name>
            <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
            <init-param>
              <param-name>contextConfigLocation</param-name>
              <!-- 此處指向的的是SpringMVC的配置文件 -->
              <param-value>classpath:META-INF/spring-mvc.xml</param-value>
            </init-param>
            <!--配置容器在啟動的時候就加載這個servlet並實例化-->
            <load-on-startup>1</load-on-startup>
        </servlet>

        <servlet-mapping>
            <servlet-name>spring</servlet-name>
            <url-pattern>/</url-pattern>
        </servlet-mapping>
        <!-- spring MVC config end-->

</web-app>

 

OK,SpringMVC配置完成,現在我們進行一下測試吧

在controller層新建一個MainController,內容如下

package com.ssm.controller;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;


/**
 * Created by XRog
 * On 2/1/2017.12:36 AM
 */
@Controller
public class MainController {

    @RequestMapping(value = "test", method = RequestMethod.GET)
    public String test(){
//        實際返回的是views/test.jsp ,spring-mvc.xml中配置過前后綴
        return "test";
    }
}

 

test.jsp網頁如下:

<html>
<body>
<center>
<h2 style="color: #ff261a;">this is my test page!</h2>
</center>
</body>
</html>

 

 

重啟Tomcat服務器, 然后瀏覽器訪問http://localhost/test如下圖所示:

 

PS: Tomcat默認端口是8080,我更改了端口號,如若你們未更改,正確的訪問地址是localhost:8080/test

OK,成功訪問。 

SpringMVC+Spring整合

 這個就十分簡單了, 配置spring-mybatis.xml這個Spring的配置文件如下(后面的mybatis配置我也將寫在這里):

<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:p="http://www.springframework.org/schema/p"
       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-3.1.xsd
                        http://www.springframework.org/schema/context
                        http://www.springframework.org/schema/context/spring-context-3.1.xsd
                        http://www.springframework.org/schema/mvc
                        http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd">

        <!-- 自動掃描 -->
        <context:component-scan base-package="com.ssm">
            <!-- 掃描時跳過 @Controller 注解的JAVA類(控制器) -->
            <context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller"/>
        </context:component-scan>

</beans>

 

完善web.xml配置文件如下:

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xmlns="http://java.sun.com/xml/ns/javaee"
         xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
         version="3.0">
        <!-- 地址為http://localhost:8080/  顯示的默認網頁-->
        <welcome-file-list>
          <welcome-file>/index.jsp</welcome-file>
        </welcome-file-list>

    <!--加載Spring的配置文件到上下文中去-->
        <context-param>
            <param-name>contextConfigLocation</param-name>
            <param-value>
                classpath:META-INF/spring-mybatis.xml
            </param-value>
        </context-param>

        <!-- spring MVC config start-->
        <servlet>
            <servlet-name>spring</servlet-name>
            <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
            <init-param>
              <param-name>contextConfigLocation</param-name>
              <!-- 此處指向的的是SpringMVC的配置文件 -->
              <param-value>classpath:META-INF/spring-mvc.xml</param-value>
            </init-param>
            <!--配置容器在啟動的時候就加載這個servlet並實例化-->
            <load-on-startup>1</load-on-startup>
        </servlet>

        <servlet-mapping>
            <servlet-name>spring</servlet-name>
            <url-pattern>/</url-pattern>
        </servlet-mapping>
        <!-- spring MVC config end-->


        <!-- Spring監聽器 -->
        <listener>
            <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
        </listener>

        <!--  字符集過濾  -->
        <filter>
            <filter-name>encodingFilter</filter-name>
            <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
            <init-param>
                <param-name>encoding</param-name>
                <param-value>UTF-8</param-value>
            </init-param>
            <init-param>
                <param-name>forceEncoding</param-name>
                <param-value>true</param-value>
            </init-param>
        </filter>
        <filter-mapping>
            <filter-name>encodingFilter</filter-name>
            <url-pattern>/*</url-pattern>
        </filter-mapping>

</web-app>

 

web.xml配置文件中更改了三處:引入Spring-mybaits配置文件 Spring的監聽器  以及 字符集過濾

 

OK,Spring+SpringMVC配置完成,下面我們開始測試:

在service寫一個TestServiceImpl實現TestService接口並實現其test()方法, 代碼如下:

package com.ssm.service.impl;

import com.ssm.service.TestService;
import org.springframework.stereotype.Service;

/**
 * Created by XRog
 * On 2/1/2017.12:58 AM
 */
@Service
public class TestServiceImpl implements TestService {
    public String test() {
        return "test";
    }
}

 

PS:這里注意寫@Service注解

MainController控制器更改如下:

package com.ssm.controller;

import com.ssm.service.TestService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.ResponseBody;


/**
 * Created by XRog
 * On 2/1/2017.12:36 AM
 */
@Controller
public class MainController {

    @Autowired
    private TestService testService;

    @RequestMapping(value = "test", method = RequestMethod.GET)
    public String test(){
//        實際返回的是views/test.jsp ,spring-mvc.xml中配置過前后綴
        return "test";
    }

    @RequestMapping(value = "springtest", method = RequestMethod.GET)
    public String springTest(){
        return testService.test();
    }
}

 

控制器這里我們運用了Spring的依賴注入自動裝配。

在瀏覽器中輸入地址http://localhost/springtest調用springtest方法     

 

yes,成功返回,說明我們之前的配置沒問題

Spring+SpringMVC+Mybatis整合

好了,現在就缺Mybatis這個框架了。。 我先給大家看些我搭建好之后的結構圖吧

 

 

 

 

我們先來編寫jdbc.properties這個配置文件,里面存放的是mybatis的一些配置

#這個是Mybatis Generator逆向工程要用到的,現在可以不配置
jdbc.driverLocation=C:\\Users\\XRog\\.m2\\repository\\mysql\\mysql-connector-java\\5.1.38\\mysql-connector-java-5.1.38.jar

#數據源 jdbc.driver=com.mysql.jdbc.Driver jdbc.url=jdbc:mysql://zxr1998.com.cn:3306/ssm jdbc.username=??? jdbc.password=??? #初始化連接池連接數 initialSize=0 #連接池最大連接數 maxActive=20 #連接池最大空閑 maxIdle=20 #連接池最小空閑 minIdle=1 #最大等待時間 maxWait=60000

 

這里連接數據庫的參數由於我是連接我網上的數據庫,因此我數據庫地址和密碼打了“???”,你們連接時改成自己本地的就OK了

<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:p="http://www.springframework.org/schema/p"
       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-3.1.xsd
                        http://www.springframework.org/schema/context
                        http://www.springframework.org/schema/context/spring-context-3.1.xsd
                        http://www.springframework.org/schema/mvc
                        http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd">

        <!-- 自動掃描 -->
        <context:component-scan base-package="com.ssm">
            <!-- 掃描時跳過 @Controller 注解的JAVA類(控制器) -->
            <context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller"/>
        </context:component-scan>

        <!-- 加載配置文件 -->
        <context:property-placeholder location="classpath:/jdbc.properties" />

        <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
            <property name="driverClassName" value="${jdbc.driver}" />
            <property name="url" value="${jdbc.url}" />
            <property name="username" value="${jdbc.username}" />
            <property name="password" value="${jdbc.password}" />
            <property name="initialSize" value="${initialSize}" />  <!--初始化連接池連接數-->
            <property name="maxActive" value="${maxActive}" />  <!--連接池最大連接數-->
            <property name="maxIdle" value="${maxIdle}" />  <!--連接池最大空閑-->
            <property name="minIdle" value="${minIdle}" />  <!--連接池最小空閑-->
            <property name="maxWait" value="${maxWait}" />  <!--連接最大等待時間-->
        </bean>


        <bean id="sqlSessionFaction" class="org.mybatis.spring.SqlSessionFactoryBean">
            <property name="dataSource" ref="dataSource" />
            <!-- 自動掃描mapping.xml文件 -->
            <property name="mapperLocations" value="classpath:/mapping/*.xml" />
        </bean>

        <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
            <property name="basePackage" value="com.ssm.mapping" />
            <property name="sqlSessionFactoryBeanName" value="sqlSessionFaction" />
        </bean>

        <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
            <property name="dataSource" ref="dataSource" />
        </bean>

</beans>

 

 

 OK,到了這里,配置結束。下面進入測試階段

實體類(domain):

package com.ssm.domain;

public class Person {
    private Long id;

    private String username;

    private String password;

    public Long getId() {
        return id;
    }

    public void setId(Long id) {
        this.id = id;
    }

  
    public String getUsername() {
        return username;
    }

    public void setUsername(String username) {
        this.username = username == null ? null : username.trim();
    }

    public String getPassword() {
        return password;
    }

    public void setPassword(String password) {
        this.password = password == null ? null : password.trim();
    }
}

 

 

mapping(我這里使用generator生成的,粘貼的時候我去掉了很多注釋,莫介意):

package com.ssm.mapping;

import com.ssm.domain.Person;
import org.apache.ibatis.annotations.Delete;
import org.apache.ibatis.annotations.Insert;
import org.apache.ibatis.annotations.ResultMap;
import org.apache.ibatis.annotations.Select;
import org.apache.ibatis.annotations.SelectKey;
import org.apache.ibatis.annotations.Update;

public interface PersonMapper {
    int deleteByPrimaryKey(Long id);

    int insert(Person record);

    int insertSelective(Person record);

    Person selectByPrimaryKey(Long id);

    int updateByPrimaryKeySelective(Person record);

    int updateByPrimaryKey(Person record);
}
 

 

<?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="com.ssm.mapping.PersonMapper">
  <resultMap id="BaseResultMap" type="com.ssm.domain.Person">
    <!--
      WARNING - @mbggenerated
      This element is automatically generated by MyBatis Generator, do not modify.
    -->
    <id column="id" jdbcType="BIGINT" property="id" />
    <result column="username" jdbcType="VARCHAR" property="username" />
    <result column="password" jdbcType="VARCHAR" property="password" />
  </resultMap>
  <sql id="Base_Column_List">
    <!--
      WARNING - @mbggenerated
      This element is automatically generated by MyBatis Generator, do not modify.
    -->
    id, username, password
  </sql>
  <insert id="insertSelective" parameterType="com.ssm.domain.Person">
    <!--
      WARNING - @mbggenerated
      This element is automatically generated by MyBatis Generator, do not modify.
    -->
    <selectKey keyProperty="id" order="AFTER" resultType="java.lang.Long">
      SELECT LAST_INSERT_ID()
    </selectKey>
    insert into person
    <trim prefix="(" suffix=")" suffixOverrides=",">
      <if test="username != null">
        username,
      </if>
      <if test="password != null">
        password,
      </if>
    </trim>
    <trim prefix="values (" suffix=")" suffixOverrides=",">
      <if test="username != null">
        #{username,jdbcType=VARCHAR},
      </if>
      <if test="password != null">
        #{password,jdbcType=VARCHAR},
      </if>
    </trim>
  </insert>
  <update id="updateByPrimaryKeySelective" parameterType="com.ssm.domain.Person">
    <!--
      WARNING - @mbggenerated
      This element is automatically generated by MyBatis Generator, do not modify.
    -->
    update person
    <set>
      <if test="username != null">
        username = #{username,jdbcType=VARCHAR},
      </if>
      <if test="password != null">
        password = #{password,jdbcType=VARCHAR},
      </if>
    </set>
    where id = #{id,jdbcType=BIGINT}
  </update>
</mapper>

 

服務層(service):

package com.ssm.service;

import com.ssm.domain.Person;

/**
 * Created by XRog
 * on 5/27/2017.
 */
public interface PersonService {

    int insert(Person person);
}
package com.ssm.service.impl;

import com.ssm.domain.Person;
import com.ssm.mapping.PersonMapper;
import com.ssm.service.PersonService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

/**
 * Created by XRog
 * on 5/27/2017.
 */
@Service
public class PersonServiceImpl implements PersonService {

    @Autowired
    private PersonMapper personMapper;

    @Override
    public int insert(Person person) {
        return personMapper.insertSelective(person);
    }
}

 

控制層(controller):

package com.ssm.controller;

import com.ssm.domain.Person;
import com.ssm.service.PersonService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
/**
 * Created by XRog
 * on 5/24/2017.
 */
@Controller
@RequestMapping("/test")
public class TestController {

    @Autowired
    private PersonService personService;

    @RequestMapping(value = "mybatis")
    public @ResponseBody String mybatis(){
        Person person = new Person();
        person.setUsername("test2");
        person.setPassword("123");
        personService.insert(person);
        return "success";
    }
}

 

OK,編寫完畢,我們重啟下服務器然后測試:輸入地址  localhost/test/mybatis  ,如果不出意外的話將返回success,這說明訪問成功

 

另外,這個ssm項目我已上傳到碼雲,公開了共享,下面是地址.這篇博客很多地方(spring+springmvc )都是借用的上篇博客的,請以下面共享的項目地址為准

https:  https://git.oschina.net/zxr_a/ssm.git

ssh:   git@git.oschina.net:zxr_a/ssm.git

 

好了,到這里就結束了,祝大家別出BUG。

  本人QQ:184370986 (千尋風)

 

掃下方的二維碼,我們就是朋友了 >_< !


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM