小工具      在线工具  汉语词典  css  js  c++  java

IDEA SpringMVC集成mybatis教程

额外说明

收录于:42天前

  目前Spring集成mybatis的教程,都比较混杂,很难找到零基础入门文章,而且很多教程实例涉及的内容很多,工程配置复杂,很难让新手跟着做完,可以运行的项目。也是 因为时间紧,没有去mybatis官网看文档,一天多时间找的中文的博客,发现部分博客实例都比较老,spring和mybatis的版本是一个问题,还有就是开发工具的不一致,MyEclipse、Eclipse EE、智能创意什么样的都有,这里建议在学习这些框架时首先确定一下开发工具,再找相对应的教程,会让你省去很多时间。

        使用mybatis,最简单的方式就是spring-boot-mybatis,创建Spring boot工程,省去mybatis配置文件,自行参阅:http://blog.csdn.net/ljheee/article/details/76599363

Mybatis最大的特点就是只需要编写将数据库表映射到实体类的接口,而不需要编写接口的实现。 Mybatis动态完成接口的实现。

Mybatis完成java实体类和数据库表的ORM映射。主要有两种方式。一种是基于注释的。上面的Spring boot就是这样集成mybatis的;另一种是基于XXXMaper.xml,使用xml文件来组装sql。 ,mybatis动态实现接口的Impl会自动加载到Spring IoC容器中。控制器可在需要时自动接线。本教程使用第二种方法来实现User实体类与数据库表之间最简单的映射,完成增删改查。

这两种方式有一个共同点:SQL语句需要程序员编写,并且对SQL的编写有一定的要求。但与此同时,SQL 灵活性的价值也发挥了作用。第一种SQL采用注解的形式编写,对于简单的操作很容易实现。第二条sql语句直接用xml编写,更能够进行复杂的sql查询等操作。

​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​很多教程都没有贴出这部分内容,这使得后者陷入了很多陷阱。

本教程工具

IDE为智能创意 2017.2

JDK环境是1.8

maven版本是maven3

Mysql版本是5.5.27

Tomcat版本是8.5

目标

完成基本的SpringMVC + Spring + MyBatis框架集成(简单示例:完成User实体类的增删改查)

数据库使用mysql

加入c3p0数据库连接池

Maven依赖版本管理

一、SSM框架整合配置

1、使用idea的maven创建一个基本的web工程,即maven-原型-webapp

提示:IDEA最好设置阿里巴巴镜像,参考http://blog.csdn.net/a1b2c3d4123456/article/details/53915056

2. 整理项目文件结构。

配置目录:

(1)在主目录下创建java目录(用于存放java源代码)

​​ 右键单击​​主目录,然后选择新建→目录,在弹出的对话框中输入java

右键单击 java 并选择将目录标记为 → 源根目录

(2)在resources目录下新建mapper和spring目录

​​​​​ 右键单击​​resources目录,然后选择New→Directory,在弹出的对话框中输入mapper。春天的情况也类似。

3.添加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>com.test</groupId>
    <artifactId>seckill</artifactId>
    <packaging>war</packaging>
    <version>1.0-SNAPSHOT</version>
    <name>seckill Maven Webapp</name>
    <url>http://maven.apache.org</url>


    <properties>
        <java.version>1.8</java.version>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>

        <!--lib setting-->
        <spring.version>4.3.3.RELEASE</spring.version>
        <jackson.version>2.6.3</jackson.version>
    </properties>


    <dependencies>
        <!-- config junit jar -->
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.12</version>
            <scope>test</scope>
        </dependency>

        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>5.1.39</version>
            <scope>runtime</scope>
        </dependency>
        <dependency>
            <groupId>c3p0</groupId>
            <artifactId>c3p0</artifactId>
            <version>0.9.1.1</version>
        </dependency>

        <!-- DAO框架:mybatis-->
        <dependency>
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis</artifactId>
            <version>3.4.1</version>
        </dependency>
        <dependency>
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis-spring</artifactId>
            <version>1.3.0</version>
        </dependency>

        <!-- servlet 相关依赖-->
        <dependency>
            <groupId>taglibs</groupId>
            <artifactId>standard</artifactId>
            <version>1.1.2</version>
        </dependency>
        <dependency>
            <groupId>javax.servlet</groupId>
            <artifactId>jstl</artifactId>
            <version>1.2</version>
        </dependency>
        <dependency>
            <groupId>com.fasterxml.jackson.core</groupId>
            <artifactId>jackson-databind</artifactId>
            <version>2.6.7</version>
        </dependency>
        <dependency>
            <groupId>javax.servlet</groupId>
            <artifactId>javax.servlet-api</artifactId>
            <version>3.1.0</version>
        </dependency>

        <!--spring依赖-->
        <!--1)核心依赖-->
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-core</artifactId>
            <version>${spring.version}</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-beans</artifactId>
            <version>${spring.version}</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-context</artifactId>
            <version>${spring.version}</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-context-support</artifactId>
            <version>${spring.version}</version>
        </dependency>

        <!--2)spring DAO-->
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-jdbc</artifactId>
            <version>${spring.version}</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-tx</artifactId>
            <version>${spring.version}</version>
        </dependency>

        <!--3)spring web-->
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-web</artifactId>
            <version>${spring.version}</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-webmvc</artifactId>
            <version>${spring.version}</version>
        </dependency>

        <!--4)spring test-->
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-test</artifactId>
            <version>${spring.version}</version>
        </dependency>

    </dependencies>
    <build>
        <finalName>seckill</finalName>
    </build>
</project>


4、添加数据库设置jdbc.properties

在 resources 目录中创建一个新的 jdbc.properties。配置信息如下:

driver=com.mysql.jdbc.Driver
url=jdbc:mysql://127.0.0.1:3306/sww
username=root
password=123456sww

idleConnectionTestPeriod=60
maxIdleTime=240
acquireIncrement=5
initialPoolSize=10
maxPoolSize=30
minPoolSize=10
autoCommitOnClose=false
checkoutTimeout=1000
acquireRetryAttempts=2


User实体类对应的数据库表:
 

SET FOREIGN_KEY_CHECKS=0;
DROP TABLE IF EXISTS `user`;
CREATE TABLE `user` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `appid` varchar(255) DEFAULT NULL,
  `name` varchar(255) DEFAULT NULL,
  `passwd` varchar(255) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=10 DEFAULT CHARSET=utf8;

5.添加mybatis全局设置mybatis-config.xml

在resources目录下新建mybatis-config.xml。配置信息如下:

<?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>
 
    <!-- mybatis全局设置 -->
    <settings>
        <!--使用数据库自增id-->
        <setting name="useGeneratedKeys" value="true" />
 
        <setting name="useColumnLabel" value="true" />
 
        <!-- 开启驼峰命名规范-->
        <setting name="mapUnderscoreToCamelCase" value="true" />
    </settings>
 
</configuration>

6.添加数据库设置spring-dao.xml

在 resources/spring 下创建一个新的 spring-dao.xml。配置信息如下:

<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" xmlns:classpath="http://www.springframework.org/schema/c"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
            http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
            http://www.springframework.org/schema/context
            http://www.springframework.org/schema/context/spring-context-3.0.xsd http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc.xsd">
 
    <!-- 启动SpringMVC的注解功能,它会自动注册HandlerMapping、HandlerAdapter、ExceptionResolver的相-->
    <mvc:annotation-driven />
    <mvc:default-servlet-handler />
 
    <!--扫描,Controller类-->
    <context:component-scan base-package="com.test"/>
 
    <context:property-placeholder location="classpath:jdbc.properties"/>
 
 
    <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource" destroy-method="close"
          p:driverClass="${driver}"
          p:jdbcUrl="${url}"
          p:user="${username}"
          p:password="${password}"
          p:idleConnectionTestPeriod="${idleConnectionTestPeriod}"
          p:maxIdleTime="${maxIdleTime}"
          p:acquireIncrement="${acquireIncrement}"
          p:initialPoolSize="${initialPoolSize}"
          p:maxPoolSize="${maxPoolSize}"
          p:minPoolSize="${minPoolSize}"
          p:autoCommitOnClose="${autoCommitOnClose}"
          p:checkoutTimeout="${checkoutTimeout}"
          p:acquireRetryAttempts="${acquireRetryAttempts}"
          p:preferredTestQuery="SELECT 1"
          p:maxConnectionAge="3000"/>
 
    <!-- mybatis文件配置,扫描所有mapper文件 -->
    <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
        <property name="dataSource" ref="dataSource"/>
        <property name="configLocation" value="classpath:mybatis-config.xml"/>
 
        <property name="typeAliasesPackage" value="com.test.entity"/>
 
        <property name="mapperLocations" value="classpath:mapper/*.xml"/>
    </bean>
 
    <!-- spring与mybatis整合配置,扫描所有dao,指定的映射器类是接口,接口方法可以用注解来指定 SQL 语句,但是 MyBatis 的映射器 XML 文件也可以用。 -->
    <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer"
          p:basePackage="com.test.dao"
          p:sqlSessionFactoryBeanName="sqlSessionFactory"/>
 
</beans>

7、修改webapp\WEB-INF\web.xml,信息如下:
 

<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
         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"
         metadata-complete="true">
 
  <!-- 配置Spring配置文件路径 -->
  <servlet>
    <servlet-name>SpringMVC</servlet-name>
    <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
    <init-param>
      <param-name>contextConfigLocation</param-name>
      <param-value>classpath:spring/spring-dao.xml</param-value>
    </init-param>
    <load-on-startup>1</load-on-startup>
  </servlet>
 
  <servlet-mapping>
    <servlet-name>SpringMVC</servlet-name>
    <url-pattern>/</url-pattern>
  </servlet-mapping>
 
  <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>
    <servlet-name>SpringMVC</servlet-name>
  </filter-mapping>
</web-app>

二、实体映射

第一部分是完成骨架工程和框架配置。接下来,添加实体类以及操作实体类的接口,完成增删改查。

1.创建User.java

右键java,创建一个包,如com.test。右键com.test创建三个包entity、dao、controller。

分别在entity、dao、controller中创建User.java、UserDao.java、UserController.java。

用户.java

package com.test.entity;
 
/**
 * 实体类:属性对应数据库表的字段
 */
public class User {
 
    private Integer id;
    private String name;
    private String passwd;
    private String appid;
 
    public User(Integer id , String name, String passwd, String appid) {
        this.id = id;
        this.name = name;
        this.passwd = passwd;
        this.appid = appid;
    }
 
 
    public User(String name, String passwd, String appid) {
        this.name = name;
        this.passwd = passwd;
        this.appid = appid;
    }
    public User(String name, String passwd) {
        this.name = name;
        this.passwd = passwd;
    }
 
    public User() {
    }
 
    public String getName() {
        return name;
    }
 
    public void setName(String name) {
        this.name = name;
    }
 
    public String getPasswd() {
        return passwd;
    }
 
    public void setPasswd(String passwd) {
        this.passwd = passwd;
    }
 
    public String getAppid() {
        return appid;
    }
 
    public void setAppid(String appid) {
        this.appid = appid;
    }
 
    public Integer getId() {
        return id;
    }
 
    public void setId(Integer id) {
        this.id = id;
    }
 
    @Override
    public String toString() {
        return "User{" +
                "id=" + id +
                ", name='" + name + '\'' +
                ", passwd='" + passwd + '\'' +
                ", appid='" + appid + '\'' +
                '}';
    }
}

UserDao.java

package com.test.dao;
 
import com.test.entity.User;
 
/**
 * DAO接口,mybatis动态完成Impl
 */
public interface UserDao {
 
    Integer addUser(User u);
 
    User findByAppid(String appid);
 
    User findById(Integer id);
 
    Integer deleteById(Integer id);
}


 

2. 创建控制器

用户控制器.java

package com.test.controller;
 
import com.test.dao.UserDao;
import com.test.entity.User;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
 
@RestController
@RequestMapping(value = "/test")
public class UserController {
 
    @Autowired(required = false)
    private UserDao userDao;
 
    @RequestMapping(value ="/phone", method = RequestMethod.GET)
    public User test(){
        return userDao.findByAppid("10524782571");
    }
 
    //-http://localhost:8080/test/add?name=abc&passwd=123&appid=95955542783
    @RequestMapping(value = "/add", method = RequestMethod.GET)
    public User save(@RequestParam("name") String name,
                     @RequestParam(value = "passwd",defaultValue = "0") String passwd,
                     @RequestParam(value = "appid",defaultValue = "0") String appid) {
        User user = new User(name,passwd,appid);
        userDao.addUser(user);
        return userDao.findById(user.getId());
    }
 
 
 
    @RequestMapping(value = "/delete", method = RequestMethod.GET)
    public void delete(@RequestParam("id") Integer id) {
        userDao.deleteById(id);
    }
 
}

最终的项目结构如下图所示:

测试:

通过浏览器输入

插入数据库并以json格式返回对象。

数据库信息

. . .

相关推荐

额外说明

结构模式-装饰者模式

文章目录 项目分析 装饰者模式结构 案例 定义抽象构件角色 定义具体构件角色 定义抽象装饰类 定义具体装饰角色类 测试类编写 jdk中的装饰者模式 代码git下载 项目分析 假设此时有一个外卖店的例子。 外卖店有炒面、炒饭等主食。 且每项主食都能具有添加

额外说明

20100625oracle学习笔记(查看oracle数据库字符集)

  select userenv('language') from dual;   查询结果:   SIMPLIFIED CHINESE_CHINA.AL32UTF8   --修改oracle数据库字符集:(在SQL Plus中)   sql> conn

额外说明

AMDR5-5600X+光威天策3200 16G AIDA64内存速度测试

1. 2400MHz,双通道 2. xmp 3200MHz

额外说明

TP5+商城小程序——微信登陆与令牌-路由变量规则与分组

QQ 1274510382 Wechat JNZ_aming 商业联盟 QQ群538250800 技术搞事 QQ群599020441 解决方案 QQ群152889761 加入我们 QQ群649347320 共享学习 QQ群674240731 纪年科技am

额外说明

Python-MySQL存储

MySQL的储存:    python2: MySQLdb    python3: PyMySQL 连接数据库:    用户名root,密码123456,端口3306 import pymysql db = pymysql.connect(host='

额外说明

☀️ 学会编程入门必备 C# 最基础知识介绍——带你认识 C# 中的几种循环结构( for & while & do...while)

前言- C# for/foreach 循环- for 流程图 foreach C# while循环- 语法 流程图 C# do...while 循环- 语法 流程图 C# 嵌套循环- 语法 循环控制语句- C# break 语句 语法 流程图 C# co

额外说明

Window11中Maven的下载安装与环境变量配置

具体步骤 1.下载 2.安装 3.配置 1.下载 链接:https://pan.baidu.com/s/1Tu_uOVpwqgh49gTt0DGu-A 提取码:ajpl 2.安装 解压即安装 3.配置 因为它依赖Java,所以首先要配置JAVA_HOME

额外说明

npm中dependencies与devDependencies的区别

这个问题的出现是我下载npm包中的依赖文件安装错地方了,导致上线项目有问题,顺便一起来看看它们的区别。 一、前言 说白了就是当初学的时候太菜,没注意到它们的区别,也没去查明白。哈哈哈 二、dependencies与devDependencies的区别 你

额外说明

C++ 多继承 即:继承多个父类

#include <iostream> using namespace std; class Base1 { public: Base1() { b1 = 1; } int b1; protected: pr

额外说明

springboot控制台日志打印到日志文件 (请求路径,执行sql,参数等)

经过几天的尝试 重终于把这个东西肝出来了 目录结构 我添加太多pom了 忘记有哪些了 也懒得找了 也就是常用的那几个吧 依赖pom 小伙子们自己添加吧!!! 首先你要把你项目跑起来 配置数据源如下 server: port: 7001 logging

ads via 小工具