全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

MyBatis 使用权威指南

什么是 MyBatis

MyBatis 是支持定制化 SQL、存储过程以及高级映射的优秀的持久层框架。MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集。MyBatis 可以对配置和原生Map使用简单的 XML 或注解,将接口和 Java 的 POJOs(Plain Old Java Objects,普通的 Java对象)映射成数据库中的记录。

SpringBoot 中使用

使用 Maven

在你的pom.xml中:

<dependency>
  <groupId>org.mybatis.spring.boot</groupId>
  <artifactId>mybatis-spring-boot-starter</artifactId>
  <version>1.2.1-SNAPSHOT</version>
</dependency>

使用 Gradle

在你的 build.gradle中:

dependencies {
  compile("org.mybatis.spring.boot:mybatis-spring-boot-starter:1.2.1-SNAPSHOT")
}

使用

目录结构

--src 
 --main
 --java
  --com.example
  --dao
   --UserDao.java
  --entity
   --User.java
  --DemoApplication.java
  --UserSex.java
 --resources
 --mapper
  --UserMapper.xml
 --application.properties

基于注解

使用MyBatis-Spring-Boot-Starter will:

将自动检测存在的数据源

将数据源输入然后创建注册一个SqlSessionFactoryBean实例

从SqlSessionFactoryBean中创建注册一个SqlSessionTemplate实例

自动扫描你的 mappers,将它们连接到SqlSessionTemplate然后将它们注册到 Spring 的上下文

我们新建一个实体类User.java,在这里我们使用 Lombok (使用说明见这篇文章)来简化代码

@Data
public class User {
  private Long id;
  private String userName;
  private String password;
  private UserSex userSex;
  private String nickName;
}

接着我们创建一张叫 user的表

DROP TABLE IF EXISTS user;
CREATE TABLE user(
 id BIGINT(20) NOT NULL AUTO_INCREMENT COMMENT '主键id',
 user_name VARCHAR(32) DEFAULT NULL COMMENT '用户名',
 password VARCHAR(32) DEFAULT NULL COMMENT '密码',
 user_sex VARCHAR(32) DEFAULT NULL ,
 nick_name VARCHAR(32) DEFAULT NULL ,
 PRIMARY KEY (id)
) ENGINE = InnoDB DEFAULT CHARSET = utf8;

然后创建一个 Dao 文件UserDao.java

@Mapper
public interface UserDao {
  @Select("SELECT * FROM user WHERE id = #{id}")
  @Results({
      @Result(property = "userName", column = "user_name"),
      @Result(property = "password", column = "password"),
      @Result(property = "userSex", column = "user_sex", javaType = UserSex.class),
      @Result(property = "nickName",column = "nick_name")
  })
  User findById(@Param("id") Long id);
  @Insert("INSERT INTO user (user_name,password,user_sex ) VALUES (#{userName},#{password},#{userSex})")
  void save(User user);
  @Update("UPDATE user set user_name = #{userName}, nick_name = #{nickName} WHERE id = #{id}")
  void update(User user);
  @Delete("DELETE FROM user where id = #{id}")
  void remove(Long id);
}

每个方法都对应的对应的 sql 语句,其中@Select注解用于查询,@Result注解将实体类属性跟数据库的字段一一对应,@Insert注解用于插入数据,@Update注解用于修改数据,@Delete注解用于删除

接下来我们简单的测试下

@RunWith(SpringRunner.class)
@SpringBootTest
public class UserMapperTest {
  @Autowired
  UserDao userDao;
  @Test
  public void test(){
    User one = new User();
    one.setUserName("张三");
    one.setPassword("123456");
    one.setUserSex(UserSex.MAN);
    userDao.save(one);
    User two = new User();
    two.setUserName("李四");
    two.setPassword("123456");
    two.setUserSex(UserSex. WOMAN);
    userDao.save(two);
  }
}

结果如下

结果

基于 XML 配置

在application.properties配置文件中新增以下配置

mybatis.type-aliases-package= com.example.entity
mybatis.mapper-locations=classpath:mapper/*.xml

然后在resources文件夹中创建mapper文件夹,然后新建一个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.example.dao.UserDao">
  <resultMap id="userMap" type="com.example.entity.User">
    <result column="id" property="id"/>
    <result column="user_name" property="userName"/>
    <result column="password" property="password"/>
    <result column="user_sex" property="userSex" javaType="com.example.UserSex"/>
    <result column="nick_name" property="nickName"/>
  </resultMap>
  <insert id="save" parameterType="com.example.entity.User">
    INSERT INTO user (user_name,password,user_sex ) VALUES (#{userName},#{password},#{userSex})
  </insert>
  <delete id="remove" parameterType="java.lang.Long">
    DELETE FROM user where id = #{id}
  </delete>
  <update id="update" parameterType="com.example.entity.User">
    UPDATE user SET user_name = #{userName}, nick_name =#{nickName} WHERE id = #{id}
  </update>
  <select id="findById" parameterType="java.lang.Long" resultMap="userMap">
    SELECT * FROM user WHERE id = #{id}
  </select>
</mapper>

然后将UserDao.java文件修改如下

public interface UserDao {
  User findById(Long id);
  void save(User user);
  void update(User user);
  void remove(Long id);
}

最后在SpringBoot的主程序上加上@MapperScan的注解将 dao 文件跟 sql 语句对应起来

@SpringBootApplication
@MapperScan("com.example.dao")
public class DemoApplication {
 public static void main(String[] args) {
 SpringApplication.run(DemoApplication.class, args);
 }
}

总结

mybatis-spring-boot-starter可以快速的通过注解来开发,十分方便,可以灵活的使用 SQL 和调整 SQL,具体用注解还是基于 XML,我觉得还是看自己的喜好。

下面看下#{}和${}的区别

#{}在底层实现上使用?做占位符来生成PreparedStatement,然后将参数传入,大多数情况都应使用这个,它更快、更安全。

${}将传入的数据直接显示生成在sql中。如:order by ${user_id},如果传入的值是111,那么解析成sql时的值为order by 111, 如果传入的值是id,则解析成的sql为order by id.

以上所述是小编给大家介绍的MyBatis 使用指南,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!


# mybatis指南  # mybatis  # 使用  # Mybatis分页插件PageHelper的使用详解  # Mybatis中注解@MapKey的使用详解  # MyBatis Generator生成代码及使用方式详解  # MyBatis Mapper代理使用方法详解  # Java的MyBatis框架中Mapper映射配置的使用及原理解析  # 详解Java的MyBatis框架中的缓存与缓存的使用改进  # oracle+mybatis 使用动态Sql当插入字段不确定的情况下实现批量insert  # 小编  # 新建一个  # 自己的  # 在这里  # 我觉得  # 在此  # 主程序  # 给大家  # 实体类  # 更快  # 这篇文章  # 几乎所有  # 以对  # 所述  # 连接到  # 都应  # 创建一个  # 使用这个  # 给我留言  # 配置文件 


相关文章: 如何选择美橙互联多站合一建站方案?  如何在宝塔面板中创建新站点?  佛山企业网站制作公司有哪些,沟通100网上服务官网?  如何获取PHP WAP自助建站系统源码?  香港网站服务器数量如何影响SEO优化效果?  浅谈Javascript中的Label语句  SAX解析器是什么,它与DOM在处理大型XML文件时有何不同?  Android自定义控件实现温度旋转按钮效果  如何快速查询网站的真实建站时间?  品牌网站制作公司有哪些,买正品品牌一般去哪个网站买?  建站之星手机一键生成:多端自适应+小程序开发快速建站指南  如何通过西部建站助手安装IIS服务器?  如何在香港服务器上快速搭建免备案网站?  标准网站视频模板制作软件,现在有哪个网站的视频编辑素材最齐全的,背景音乐、音效等?  制作电商网页,电商供应链怎么做?  高防服务器租用如何选择配置与防御等级?  哈尔滨网站建设策划,哈尔滨电工证查询网站?  如何在IIS服务器上快速部署高效网站?  高性价比服务器租赁——企业级配置与24小时运维服务  如何做静态网页,sublimetext3.0制作静态网页?  定制建站策划方案_专业建站与网站建设方案一站式指南  建站之星后台密码遗忘或太弱?如何重置与强化?  制作网站怎么制作,*游戏网站怎么搭建?  微信h5制作网站有哪些,免费微信H5页面制作工具?  香港服务器选型指南:免备案配置与高效建站方案解析  如何快速上传建站程序避免常见错误?  如何自定义建站之星模板颜色并下载新样式?  网站制作公司排行榜,抖音怎样做个人官方网站  弹幕视频网站制作教程下载,弹幕视频网站是什么意思?  深圳网站制作的公司有哪些,dido官方网站?  西安专业网站制作公司有哪些,陕西省建行官方网站?  专业公司网站制作公司,用什么语言做企业网站比较好?  家族网站制作贴纸教程视频,用豆子做粘帖画怎么制作?  定制建站价位费用解析与套餐推荐全攻略  电商网站制作公司有哪些,1688网是什么意思?  如何获取上海专业网站定制建站电话?  如何制作一个表白网站视频,关于勇敢表白的小标题?  建站之星3.0如何解决常见操作问题?  建站之星展会模版如何一键下载生成?  太原网站制作公司有哪些,网约车营运证查询官网?  建站主机功能解析:服务器选择与快速搭建指南  网站网页制作电话怎么打,怎样安装和使用钉钉软件免费打电话?  做企业网站制作流程,企业网站制作基本流程有哪些?  惠州网站建设制作推广,惠州市华视达文化传媒有限公司怎么样?  网站代码制作软件有哪些,如何生成自己网站的代码?  焦点电影公司作品,电影焦点结局是什么?  如何配置WinSCP新建站点的密钥验证步骤?  网站制作模板下载什么软件,ppt模板免费下载网站?  广州网站设计制作一条龙,广州巨网网络科技有限公司是干什么的?  高性能网站服务器配置指南:安全稳定与高效建站核心方案 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。