专栏首页Hcode网站SSM框架(五)Mybatis的配置和CRUD操作

SSM框架(五)Mybatis的配置和CRUD操作

Mybatis的简述

MyBatis 是一款优秀的持久层框架,避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集的过程,可以使用简单的 XML 或注解来配置和映射原生信息,将接口和 Java 的 实体类 【Plain Old Java Objects,普通的 Java对象】映射成数据库中的记录。

MyBatis 是一个半自动化的ORM框架 (Object Relationship Mapping) →对象关系映射

Mybatis的依赖导入以及文件配置

Mybatis的依赖

<dependency>
   <groupId>org.mybatis</groupId>
   <artifactId>mybatis</artifactId>
   <version>3.5.2</version>
</dependency>
<dependency>
   <groupId>mysql</groupId>
   <artifactId>mysql-connector-java</artifactId>
   <version>5.1.47</version>
</dependency>

连接数据库的配置datasourse.properties

driver=com.mysql.jdbc.Driver
#Mysql8.0+ 需要添加时区配置 &serverTimezone=Asia/shanghai
url=jdbc:mysql://localhost:3306/mybatis?useSSL=true&useUnicode=true&characterEncoding=utf8
username=root
password=123456

Mybatis的核心配置文件

<?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>
   <!--导入properties文件-->
   <properties resource="db.properties"/>

   <environments default="development">
       <environment id="development">
           <transactionManager type="JDBC"/>
           <dataSource type="POOLED">
               <property name="driver" value="${driver}"/>
               <property name="url" value="${url}"/>
               <property name="username" value="${username}"/>
               <property name="password" value="${password}"/>
           </dataSource>
       </environment>
   </environments>
   <mappers>
       <mapper resource="mapper/UserMapper.xml"/>
   </mappers>
</configuration>

Mybatis的CRUD操作

Mybatis的工具类

import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
import java.io.IOException;
import java.io.InputStream;

public class MybatisUtils {

   private static SqlSessionFactory sqlSessionFactory;

   static {
       try {
           String resource = "mybatis-config.xml";
           InputStream inputStream = Resources.getResourceAsStream(resource);
           sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
      } catch (IOException e) {
           e.printStackTrace();
      }
  }

   //获取SqlSession连接
   public static SqlSession getSession(){
       return sqlSessionFactory.openSession();
  }

}

实体类例子

public class User {

   private int id;  //id
   private String name;   //姓名
   private String pwd;   //密码

   //构造,有参,无参
   //set/get
   //toString()

}

Mapper接口类

import top.hcode.pojo.User;
import java.util.List;

public interface UserMapper {
   List<User> selectUser();
   //添加一个用户
   int addUser(User user);
   //修改一个用户
   int updateUser(User user);
   //根据id删除用户
   int deleteUser(int id);
}

Mapper.xml书写SQL语句

<?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="top.hcode.dao.UserMapper">
 <select id="selectUser" resultType="top.hcode.pojo.User"> //id为对应UserMapper的方法名
  select * from user
 </select>
 <insert id="addUser" parameterType="top.hcode.pojo.User">
    insert into user (id,name,pwd) values (#{id},#{name},#{pwd})
</insert>
<update id="updateUser" parameterType="top.hcode.pojo.User">
  update user set name=#{name},pwd=#{pwd} where id = #{id}
</update>
<delete id="deleteUser" parameterType="int">
  delete from user where id = #{id}
</delete>
</mapper>

添加Maven静态资源过滤

<resources>
   <resource>
       <directory>src/main/java</directory>
       <includes>
           <include>**/*.properties</include>
           <include>**/*.xml</include>
       </includes>
       <filtering>false</filtering>
   </resource>
   <resource>
       <directory>src/main/resources</directory>
       <includes>
           <include>**/*.properties</include>
           <include>**/*.xml</include>
       </includes>
       <filtering>false</filtering>
   </resource>
</resources>

测试

public class MyTest {
   @Test
   public void selectUser() {
       SqlSession session = MybatisUtils.getSession();
       //方法一:
       //List<User> users = session.selectList("top.hcode.mapper.UserMapper.selectUser");
       //方法二:
       UserMapper mapper = session.getMapper(UserMapper.class);
       List<User> users = mapper.selectUser();

       for (User user: users){
           System.out.println(user);
      }
       session.close();
       //添加
       User user = new User(5,"HZH","牛逼");
       int i = mapper.addUser(user);
       System.out.println(i);
       session.commit(); //提交事务,重点!不写的话不会提交到数据库
       session.close();
       //更新
       User user = mapper.selectUserById(1);
       user.setPwd("6666");
       int i = mapper.updateUser(user);
       System.out.println(i);
       session.commit(); //提交事务,重点!不写的话不会提交到数据库
       session.close();
       //删除
       int i = mapper.deleteUser(5);
       System.out.println(i);
       session.commit(); //提交事务,重点!不写的话不会提交到数据库
       session.close();
  }
}

所有的增删改操作都需要提交事务!

模糊查询

拼接通配符,防止SQL注入!!!

<select id=”selectlike” parameterType="map">
    select * from foo where bar like "%"#{value}"%"
</select>

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • Python3可视化爬取教务系统实现查询功能

    今天来补充之前的界面操作系统,为学生查询操作系统2.0版本,依旧是用wxpython来做一个可视化的操作界面,用的工具依然是selenium库,beautifu...

    HcodeBlogger
  • SSM框架(六)Mybatis实现一对多和多对一查询

    HcodeBlogger
  • Spring Boot(五)安全框架SpringSecurity和Shiro的集成

    2. 自定义UserRealm类:用于查询用户的角色和权限信息并保存到权限管理器

    HcodeBlogger
  • SpringMVC+RestFul详细示例实战教程一(实现跨域访问+postman测试)

    注意:由于文章篇幅太长,超出了字数,这是文章的第一部分,明天分享文章的第二部分,请见谅!

    好好学java
  • Spring Boot入门教程2-1、使用Spring Boot+MyBatis访问数据库(CURD)注解版

    本项目构建基于:https://ken.io/note/springboot-course-basic-helloworld

    KenTalk
  • 重采样技术—Bootstrap

    版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明...

    于小勇
  • python自学argparse模块

    argparse是python用于解析命令行参数和选项的标准模块,用于代替已经过时的optparse模块

    py3study
  • 推荐 11 个 GitHub 上比较热门的 Java 项目

    https://github.com/skylot/jadx Star 13804

    良月柒
  • 推荐11个GitHub上比较热门的Java项目

    https://github.com/skylot/jadx Star 13804

    用户5224393
  • 好久没水文章了

    还记得刚刚开始玩 webpack 的时候就想着 webpack-dev-server 在本地搞开发这么好用,那我能不能给弄到服务器上让它也能一直在后台运行呢,这...

    凌虚

扫码关注云+社区

领取腾讯云代金券