SpringBoot mybatis方式實(shí)現(xiàn)增刪改查

SpringBoot mybatis方式實(shí)現(xiàn)增刪改查
首先看一下目錄結(jié)構(gòu)


WeChat8ac39b77d612cd05cf4a0c1775552328.png
application.yml文件
server:
  port: 8080

spring:
    datasource:
        name: test
        url: jdbc:mysql://127.0.0.1:3306/myDataBase
        username: root
        password: 1qaz2wsx
        type: com.alibaba.druid.pool.DruidDataSource
        driver-class-name: com.mysql.jdbc.Driver
        filters: stat
        maxActive: 20
        initialSize: 1
        maxWait: 60000
        minIdle: 1
        timeBetweenEvictionRunsMillis: 60000
        minEvictableIdleTimeMillis: 300000
        validationQuery: select 'x'
        testWhileIdle: true
        testOnBorrow: false
        testOnReturn: false
        poolPreparedStatements: true
        maxOpenPreparedStatements: 20

mybatis:
  mapper-locations: classpath:mapping/*.xml
  type-aliases-package: com.winter.model
Model 代碼如下
package com.winter.model;

public class User {
    private Integer userId;

    private String userName;

    private String userAge;


    public Integer getUserId() {
        return userId;
    }

    public void setUserId(Integer userId) {
        this.userId = userId;
    }

    public String getUserName() {
        return userName;
    }

    public void setUserName(String userName) {
        this.userName = userName == null ? null : userName.trim();
    }

    public String getUserAge() {
        return userAge;
    }

    public void setUserAge(String userAge) {
        this.userAge = userAge == null ? null : userAge.trim();
    }


}
ViewController 代碼都加了注釋
package com.winter.controller;

import com.winter.model.User;
import com.winter.service.UserService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;

@Controller
@RequestMapping(value = "/user")
public class UserController {

    @Autowired
    private UserService userService;

    /*Get方式方便web測試*/

    /*增加用戶*/
    // http://localhost:8080/user/addUser/?userName=Alex&userAge=20
    @ResponseBody
    @RequestMapping(value = "/addUser", produces = {"application/json;charset=UTF-8"})
    public int addUser(User user){
        return userService.addUser(user);
    }

    /*刪除用戶*/
    // http://localhost:8080/user/deleteUser/?userId=2
    @ResponseBody
    @RequestMapping(value = "/deleteUser",produces = {"application/json;charset=UTF-8"})
    public  int deleteUser(User user){
        return userService.deleteUser(user);
    }

    /*修改用戶*/
    // http://localhost:8080/user/updateUser/?userId=3&userName=劉牧師&userAge=50
    @ResponseBody
    @RequestMapping(value = "/updateUser",produces = {"application/json;charset=UTF-8"})
    public  int  updateUser(User user){
        return userService.updateUser(user);
    }

    /*根據(jù)UserId查找用戶*/
    // http://localhost:8080/user/getUserById/?userId=3
    @ResponseBody
    @RequestMapping(value = "/getUserById", produces = {"application/json;charset=UTF-8"})
    public User getUserById(User user){
        return userService.getUserById(user);
    }

    /*查詢所有用戶*/
    // http://localhost:8080/user/getAllUsers
    @ResponseBody
    @RequestMapping(value = "/getAllUsers", produces = {"application/json;charset=UTF-8"})
    public Object findAllUser(){
        return userService.findAllUser();
    }
}

UserService
package com.winter.service;

import com.winter.model.User;

import java.util.List;

public interface UserService {

    int addUser(User user);

    int deleteUser(User user);

    int updateUser(User user);

    User getUserById(User user);

    List<User> findAllUser();
}
UserServiceImpI
package com.winter.service;

import com.winter.mapper.UserMapper;
import com.winter.model.User;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

import java.util.List;

@Service
public class UserServiceImpl implements  UserService{
    @Autowired
    private UserMapper userMapper;

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

    @Override
    public int deleteUser(User user){
        return userMapper.deleteUser(user);
    }

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

    @Override
    public  User getUserById(User user){
        return userMapper.getUserById(user);
    }

    @Override
    public List<User> findAllUser() {
        return userMapper.selectAllUser();
    }
}
UserMapper
package com.winter.mapper;

import com.winter.model.User;

import java.util.List;

public interface UserMapper {

    int addUser(User user);

    int deleteUser(User user);

    int updateUser(User user);

    User getUserById(User user);

    List<User> selectAllUser();
}
UserMapper.xml
<?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.winter.mapper.UserMapper" >

    <insert id="addUser" parameterType ="com.winter.model.User">
    insert  into tb_user(user_name,user_age)
    values (#{userName},#{userAge})
    </insert>

    <delete id="deleteUser" parameterType ="com.winter.model.User">
    delete from tb_user where user_id = #{userId}
    </delete>

    <update id="updateUser" parameterType ="com.winter.model.User">
    update  tb_user set user_name =#{userName},user_age = #{userAge}  where  user_id= #{userId}
    </update>

    <select id="getUserById" parameterType ="com.winter.model.User" resultType="com.winter.model.User">
    select  user_id userId,user_name userName,user_age userAge
    from tb_user where user_id= #{userId}
    </select>

    <select id="selectAllUser" resultType="com.winter.model.User">
    select  user_id userId,user_name userName,user_age userAge
    from tb_user
    </select>


</mapper>

Demo:https://github.com/destinyzhao/springboot-mybatis-dome

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末曙强,一起剝皮案震驚了整個濱河市示损,隨后出現(xiàn)的幾起案子弊予,更是在濱河造成了極大的恐慌,老刑警劉巖类垫,帶你破解...
    沈念sama閱讀 211,265評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異琅坡,居然都是意外死亡悉患,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,078評論 2 385
  • 文/潘曉璐 我一進(jìn)店門榆俺,熙熙樓的掌柜王于貴愁眉苦臉地迎上來售躁,“玉大人,你說我怎么就攤上這事茴晋∨憬荩” “怎么了?”我有些...
    開封第一講書人閱讀 156,852評論 0 347
  • 文/不壞的土叔 我叫張陵诺擅,是天一觀的道長揩局。 經(jīng)常有香客問我,道長掀虎,這世上最難降的妖魔是什么凌盯? 我笑而不...
    開封第一講書人閱讀 56,408評論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮烹玉,結(jié)果婚禮上驰怎,老公的妹妹穿的比我還像新娘。我一直安慰自己二打,他們只是感情好县忌,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,445評論 5 384
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著继效,像睡著了一般症杏。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上瑞信,一...
    開封第一講書人閱讀 49,772評論 1 290
  • 那天厉颤,我揣著相機(jī)與錄音,去河邊找鬼凡简。 笑死逼友,一個胖子當(dāng)著我的面吹牛精肃,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播帜乞,決...
    沈念sama閱讀 38,921評論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼司抱,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了黎烈?” 一聲冷哼從身側(cè)響起习柠,我...
    開封第一講書人閱讀 37,688評論 0 266
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎照棋,沒想到半個月后津畸,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,130評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡必怜,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,467評論 2 325
  • 正文 我和宋清朗相戀三年肉拓,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片梳庆。...
    茶點(diǎn)故事閱讀 38,617評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡暖途,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出膏执,到底是詐尸還是另有隱情驻售,我是刑警寧澤,帶...
    沈念sama閱讀 34,276評論 4 329
  • 正文 年R本政府宣布更米,位于F島的核電站欺栗,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏征峦。R本人自食惡果不足惜迟几,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,882評論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望栏笆。 院中可真熱鬧类腮,春花似錦、人聲如沸蛉加。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,740評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽针饥。三九已至厂抽,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間丁眼,已是汗流浹背筷凤。 一陣腳步聲響...
    開封第一講書人閱讀 31,967評論 1 265
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留户盯,地道東北人嵌施。 一個月前我還...
    沈念sama閱讀 46,315評論 2 360
  • 正文 我出身青樓饲化,卻偏偏與公主長得像莽鸭,于是被迫代替她去往敵國和親吗伤。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,486評論 2 348

推薦閱讀更多精彩內(nèi)容