SpringMVC+Mybatis全套增删改(小白入门)

作者:刘佳乐

  • 2020.6.27

先到官网了解mybatis的语法:https://mybatis.org/mybatis-3/zh/index.html

一、创建如下所示项目

SpringMVC+Mybatis全套增删改(小白入门)_第1张图片

二、在src下的cn.kgc.vo包下创建 Dept.java

package cn.kgc.vo;
public class Dept {

  private long deptno;
  private String dname;
  private String loc;


  public long getDeptno() {
    return deptno;
  }

  public void setDeptno(long deptno) {
    this.deptno = deptno;
  }


  public String getDname() {
    return dname;
  }

  public void setDname(String dname) {
    this.dname = dname;
  }


  public String getLoc() {
    return loc;
  }

  public void setLoc(String loc) {
    this.loc = loc;
  }

}

三、在src下的cn.kgc.mapper包下创建 DeptMapper.java

package cn.kgc.mapper;

import cn.kgc.vo.Dept;
import org.apache.ibatis.annotations.Delete;
import org.apache.ibatis.annotations.Insert;
import org.apache.ibatis.annotations.Select;
import org.apache.ibatis.annotations.Update;

import java.util.List;

public interface DeptMapper {
    @Select("select * from dept")
    List<Dept> selectDept();

    @Insert("insert into dept(dname) values (#{dname})")
    int insertDept(Dept dept);

    @Update("update dept set dname=#{dname} values deptno=#{deptno}")
    int updateDept(Dept dept);

    @Delete("delete  from dept where deptno=#{deptno}")
    int deleteDept(Integer deptno);
}

四、在src下的cn.kgc.service包下创建 DeptService.java

package cn.kgc.service;

import cn.kgc.vo.Dept;

import java.util.List;

public interface DeptService {
    List<Dept> showDept();

    int add(Dept dept);

    int edit(Dept dept);

    int del(Integer deptno);
}

五、在src下的cn.kgc.service包下创建 DeptServiceImpl.java

package cn.kgc.service;

import cn.kgc.mapper.DeptMapper;
import cn.kgc.vo.Dept;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;

import java.util.List;

@Service
@Transactional
public class DeptServiceImpl implements DeptService {

    @Autowired
    private DeptMapper deptMapper;

    @Override
    public List<Dept> showDept() {
        return deptMapper.selectDept();
    }
    @Override
    public int add(Dept dept) {
        return deptMapper.insertDept(dept);
    }
    @Override
    public int edit(Dept dept) {
        return deptMapper.updateDept(dept);
    }
    @Override
    public int del(Integer deptno) {
        return deptMapper.deleteDept(deptno);
    }
}

六、在src下的cn.kgc.controller包下创建 CenterController.java

package cn.kgc.controller;

import cn.kgc.mapper.DeptMapper;
import cn.kgc.vo.Dept;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RestController;

import java.util.List;

@RestController
public class CenterController  {

    @Autowired
    private DeptMapper deptMapper;

    @GetMapping("/data.do")
    public List<Dept> showDept() {
        return deptMapper.selectDept();
    }
    
    @PostMapping("/add.do")
    public int add(Dept dept) {
        return deptMapper.insertDept(dept);
    }
    
    @PostMapping("/edit.do")
    public int edit(Dept dept) {
        return deptMapper.updateDept(dept);
    }

    @GetMapping("/del.do")
    public int del(Integer deptno) {
        return deptMapper.deleteDept(deptno);
    }
}

七、在Webapp下的WEB-INF下创建web.xml



<web-app>
  <filter>
    <filter-name>characterfilter-name>
    <filter-class>org.springframework.web.filter.CharacterEncodingFilterfilter-class>
    <init-param>
      <param-name>encodingparam-name>
      <param-value>UTF-8param-value>
    init-param>
  filter>
  <filter-mapping>
    <filter-name>characterfilter-name>
    <url-pattern>/*url-pattern>
  filter-mapping>
  
  <servlet>
    <servlet-name>springMVCservlet-name>
    <servlet-class>org.springframework.web.servlet.DispatcherServletservlet-class>
    
  servlet>
  <servlet-mapping>
    <servlet-name>springMVCservlet-name>
    <url-pattern>*.dourl-pattern>
  servlet-mapping>
  
  
web-app>

八、在Webapp下的WEB-INF下创建springMVC-servlet.xml.xml


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

    
    <contex:component-scan base-package="cn.kgc"/>
    
    <mvc:annotation-driven/>
    
    <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
        <property name="driverClassName" value="com.mysql.jdbc.Driver"/>
        <property name="url" value="jdbc:mysql://localhost:3306/kh85"/>
        <property name="username" value="root"/>
        <property name="password" value="root"/>
    bean>
    
    <bean id="sqlSessionFactoryBean" class="org.mybatis.spring.SqlSessionFactoryBean">
        <property name="dataSource" ref="dataSource"/>
    bean>
    
    <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
        <property name="dataSource" ref="dataSource"/>
    bean>
    
    <tx:annotation-driven/>
    
    <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
        <property name="basePackage" value="cn.kgc.mapper"/>
    bean>
beans>

九、运行如下(没有写页面)

你可能感兴趣的:(spring,mybatis,spring)