SpringBoot學習10:springboot整合mybatis

需求:經過使用 SpringBoot+SpringMVC+MyBatis 整合實現一個對數據庫中的 t_user 表的 CRUD 的操做html

一、建立maven項目,添加項目所需依賴

<!--springboot項目依賴的父項目-->
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.0.0.RELEASE</version>
    </parent>

    <dependencies>
        <!--注入springboot啓動器-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

        <!--注入springboot對thymeleaf視圖技術的支持-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-thymeleaf</artifactId>
        </dependency>
        <!--mybaits啓動器,注入springboot對mybatis的支持-->
        <dependency>
            <groupId>org.mybatis.spring.boot</groupId>
            <artifactId>mybatis-spring-boot-starter</artifactId>
            <version>1.1.1</version>
        </dependency>
        <!-- mysql 數據庫驅動 -->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
        </dependency>
        <!-- 阿里巴巴druid數據庫鏈接池 -->
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>druid</artifactId>
            <version>1.0.9</version>
        </dependency>
        <!-- jpa實體類規範 -->
        <dependency>
            <groupId>javax.persistence</groupId>
            <artifactId>persistence-api</artifactId>
            <version>1.0</version>
        </dependency>
    </dependencies>

二、在resource文件夾下添加application.properties全局配置文件

#數據庫鏈接信息
spring.datasource.driverClassName=com.mysql.jdbc.Driver
spring.datasource.url=jdbc:mysql://127.0.0.1:3306/springboot
spring.datasource.username=root
spring.datasource.password=duan
#數據庫鏈接池
spring.datasource.type=com.alibaba.druid.pool.DruidDataSource
#配置mybatis中實體類xml配置文件中實體類所在文件夾,若是配置了,在xml配置文件中參數、返回值實體類能夠不寫包名
mybatis.type-aliases-package=com.bjsxt.pojo
#mapper接口xml文件所在位置
mybatis.mapper-locations=classpath:mapping/*.xml

三、數據庫設計

建立數據庫

DROP TABLE IF EXISTS `t_user`;
CREATE TABLE `t_user` (
  `id` bigint(10) NOT NULL AUTO_INCREMENT,
  `name` varchar(255) DEFAULT NULL,
  `age` smallint(3) DEFAULT NULL,
  `hobby` varchar(255) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=7 DEFAULT CHARSET=utf8;

添加數據

INSERT INTO `t_user` VALUES ('1', '張三', '22', '羽毛球');
INSERT INTO `t_user` VALUES ('2', '李四', '20', '籃球');
INSERT INTO `t_user` VALUES ('3', '王五', '24', '排球');

四、建立實體類User

package com.bjsxt.pojo;

import javax.persistence.*;

/**
 * Created by Administrator on 2019/2/10.
 */
@Entity
@Table(name = "t_user")
public class User {

    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    @Column(name = "id")
    private Long id;

    @Column(name = "name")
    private String name;

    @Column(name = "age")
    private int age;

    @Column(name = "hobby")
    private String hobby;

    public Long getId() {
        return id;
    }

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

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public int getAge() {
        return age;
    }

    public void setAge(int age) {
        this.age = age;
    }

    public String getHobby() {
        return hobby;
    }

    public void setHobby(String hobby) {
        this.hobby = hobby;
    }
}

五、建立mapper接口以及接口映射的配置文件

package com.bjsxt.mapper;

import com.bjsxt.pojo.User;
import org.apache.ibatis.annotations.Mapper;

import java.util.List;

/**
 * Created by Administrator on 2019/2/10.
 */
public interface UserMapper {

    /**
     * 查詢全部的用戶
     * @return
     */
    List<User> selectAllUser();

    /**
     * 查詢單個用戶
     */
    User selectUserById(Integer id);

    /**
     * 添加用戶
     */
    void addUser(User user);

    /**
     * 修改用戶
     */
    void updateUser(User user);

    /**
     * 刪除用戶
     */
    void deleteUser(Integer id);

}
<?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.bjsxt.mapper.UserMapper">
    <select id="selectAllUser" resultType="User">
        select * from t_user;
    </select>

    <select id="selectUserById" parameterType="java.lang.Integer" resultType="User">
        select * from t_user where id=#{id};
    </select>

    <insert id="addUser" parameterType="User">
        insert into t_user(name,age,hobby) values(#{name},#{age},#{hobby});
    </insert>

    <update id="updateUser" parameterType="User">
        update t_user set name=#{name},age=#{age},hobby=#{hobby} where id=#{id};
    </update>

    <delete id="deleteUser" parameterType="java.lang.Integer">
        delete from t_user where id=#{id};
    </delete>
</mapper>

六、建立業務層

接口:

package com.bjsxt.service;

import com.bjsxt.pojo.User;

import java.util.List;

/**
 * Created by Administrator on 2019/2/10.
 */
public interface UserService {

    /**
     * 查詢全部的用戶
     * @return
     */
    List<User> selectAllUser();

    /**
     * 查詢單個用戶
     */
    User selectUserById(Integer id);

    /**
     * 添加用戶
     */
    void addUser(User user);

    /**
     * 修改用戶
     */
    void updateUser(User user);

    /**
     * 刪除用戶
     */
    void deleteUser(Integer id);

}

實現類

package com.bjsxt.service.impl;

        import com.bjsxt.mapper.UserMapper;
        import com.bjsxt.pojo.User;
        import com.bjsxt.service.UserService;
        import org.springframework.beans.factory.annotation.Autowired;
        import org.springframework.stereotype.Service;
        import org.springframework.transaction.annotation.Transactional;

        import java.util.List;

/**
 * Created by Administrator on 2019/2/10.
 */
@Service
@Transactional //service層打開事務
public class UserServiceImpl implements UserService {

    @Autowired
    private UserMapper userMapper;

    @Override
    public List<User> selectAllUser() {
        return userMapper.selectAllUser();
    }

    @Override
    public User selectUserById(Integer id) {
        return userMapper.selectUserById(id);
    }

    @Override
    public void addUser(User user) {
        userMapper.addUser(user);
    }

    @Override
    public void updateUser(User user) {
        userMapper.updateUser(user);
    }

    @Override
    public void deleteUser(Integer id) {
        userMapper.deleteUser(id);
    }
}

七、建立controller

package com.bjsxt.controller;

import com.bjsxt.pojo.User;
import com.bjsxt.service.UserService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;

import javax.servlet.http.HttpServletRequest;

/**
 * Created by Administrator on 2019/2/10.
 */
@Controller
@RequestMapping("user")
public class UserController {

    @Autowired
    private UserService userService;

    /**
     * 去用戶列表頁面
     * @param model
     * @return
     */
    @RequestMapping("toUserList")
    public String toUserList(Model model){
        model.addAttribute("userList",userService.selectAllUser());
        return "user_list";
    }

    /**
     * 去用戶編輯添加頁面
     */
    @RequestMapping("toUserEdit")
    public String toUserEdit(HttpServletRequest request,Model model){
        String id=request.getParameter("id");
        if(null!=id&&!"".equals(id)){   //編輯
            User user=userService.selectUserById(Integer.parseInt(id));
            model.addAttribute("user",user);
        }
        return "user_edit";
    }
    /**
     * 用戶添加或編輯
     */
    @RequestMapping(value = "userEdit",method = RequestMethod.POST)
    public String userEdit(HttpServletRequest request,User user){
        if(null!=user.getId()&&!"".equals(user.getId())){   //編輯
            userService.updateUser(user);
        }else{  //添加
            userService.addUser(user);
        }
        return "redirect:/user/toUserList";
    }

    /**
     * 用戶刪除
     */
    @RequestMapping("deleteUser")
    public String deleteUser(Integer id){
        userService.deleteUser(id);
        return "redirect:/user/toUserList";
    }

}

八、編寫頁面,視圖層採用thymeleaf技術

用戶列表頁面user_list.html

<!DOCTYPE html >
<html lang="en" xmlns:th="http://www.thymeleaf.org">
<head>
    <meta charset="UTF-8">
    <title>用戶列表</title>
</head>
<body>
    <div>
        <div><a href="toUserEdit">添加</a></div>
        <table>
            <tr>
                <th>用戶id</th>
                <th>用戶姓名</th>
                <th>用戶年齡</th>
                <th>用戶愛好</th>
                <th>操做</th>
            </tr>
            <tr th:each="user:${userList}">
                <td th:text="${user.id}"></td>
                <td th:text="${user.name}"></td>
                <td th:text="${user.age}"></td>
                <td th:text="${user.hobby}"></td>
                <td>
                    <a th:href="@{/user/toUserEdit(id=${user.id})}">編輯</a>
                    <a th:href="@{/user/deleteUser(id=${user.id})}">刪除</a>
                </td>
            </tr>
        </table>
    </div>
</body>
</html>

用戶添加編輯頁面user_edit.html

<!DOCTYPE html>
<html lang="en" xmlns:th="http://www.thymeleaf.org">
<head>
    <meta charset="UTF-8">
    <title>用戶編輯添加</title>
</head>
<body>
    <form action="/user/userEdit" method="post">
        <input type="hidden" name="id" th:field="${user.id}">
        用戶姓名:<input type="text" name="name" th:field="${user.name}"><br />
        用戶年齡:<input type="text" name="age" th:field="${user.age}"><br />
        用戶愛好:<input type="text" name="hobby" th:field="${user.hobby}"><br />
        <input type="submit" value="提交">
    </form>
</body>
</html>

九、編寫啓動類

package com.bjsxt;

import org.mybatis.spring.annotation.MapperScan;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

/**
 * Created by Administrator on 2019/2/10.
 */
@SpringBootApplication
@MapperScan("com.bjsxt.mapper") //指定mapper接口所在的位置
public class App {

    public static void main(String[] args){
        SpringApplication.run(App.class,args);
    }
}

在瀏覽器中訪問便可http://localhost:8080/user/toUserListjava

 十、最後目錄結構mysql

相關文章
相關標籤/搜索