0
点赞
收藏
分享

微信扫一扫

MyBatis入门及增删改查

兽怪海北 2022-03-30 阅读 146
java

一、MyBatis简介

1、MyBatis历史

MyBatis最初是Apache的一个开源项目iBatis, 2010年6月这个项目由Apache Software Foundation迁 移到了Google Code。随着开发团队转投Google Code旗下, iBatis3.x正式更名为MyBatis。代码于 2013年11月迁移到Github。 iBatis一词来源于“internet”和“abatis”的组合,是一个基于Java的持久层框架。 iBatis提供的持久层框架 包括SQL Maps和Data Access Objects(DAO)。

2、MyBatis特性

1) MyBatis 是支持定制化 SQL、存储过程以及高级映射的优秀的持久层框架

2) MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集

3) MyBatis可以使用简单的XML或注解用于配置和原始映射,将接口和Java的POJO(Plain Old Java Objects,普通的Java对象)映射成数据库中的记录

4) MyBatis 是一个 半自动的ORM(Object Relation Mapping)框架

3、MyBatis下载

MyBatis下载地址:https://github.com/mybatis/mybatis-3 

4、和其它持久化层技术对比

JDBC

  • SQL 夹杂在Java代码中耦合度高,导致硬编码内伤
  • 维护不易且实际开发需求中 SQL 有变化,频繁修改的情况多见
  • 代码冗长,开发效率低

Hibernate 和 JPA

  • 操作简便,开发效率高
  • 程序中的长难复杂 SQL 需要绕过框架
  • 内部自动生产的 SQL,不容易做特殊优化
  • 基于全映射的全自动框架,大量字段的 POJO 进行部分映射时比较困难。
  • 反射操作太多,导致数据库性能下降

MyBatis

  • 轻量级,性能出色
  • SQL 和 Java 编码分开,功能边界清晰。Java代码专注业务、SQL语句专注数据
  • 开发效率稍逊于HIbernate,但是完全能够接受

 二、搭建MyBatis

1、开发环境

JDK:1.8

IDE:idea 2019.3.3

构建工具:maven 3.5

MySQL版本:MySQL 5.7

MyBatis版本:MyBatis 3.4.5

2、创建maven工程

a>打包方式:jar

b>引入依赖

<dependencies>
<!-- Mybatis核心 -->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.5.7</version>
</dependency>
<!-- junit测试 -->
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.12</version>
<scope>test</scope>
</dependency>
<!-- MySQL驱动 -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.3</version>
</dependency>
</dependencies>

3、创建MyBatis的核心配置文件

习惯上命名为mybatis-config.xml,这个文件名仅仅只是建议,并非强制要求。将来整合Spring 之后,这个配置文件可以省略,所以大家操作时可以直接复制、粘贴。 核心配置文件主要用于配置连接数据库的环境以及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>
<!--设置连接数据库的环境-->
<environments default="development">
<environment id="development">
<transactionManager type="JDBC"/>
<dataSource type="POOLED">
<property name="driver" value="com.mysql.jdbc.Driver"/>
<property name="url"
value="jdbc:mysql://localhost:3306/t272"/>
<property name="username" value="root"/>
<property name="password" value="123"/>
</dataSource>
</environment>
</environments>
<!--引入映射文件-->
<mappers>
<mapper resource="mappers/UserMapper.xml"/>
</mappers>
</configuration>

4、创建mapper接口

public interface UserMapper {
/**
* 添加用户信息
*/
int insertUser();
}

 

5、创建MyBatis的映射文件

相关概念:ORM(Object Relationship Mapping)对象关系映射。

  • 对象:Java的实体类对象
  • 关系:关系型数据库
  • 映射:二者之间的对应关系
Java概念数据库概念
属性字段/列
对象记录/行

 

?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.atguigu.mybatis.mapper.UserMapper">
<!--int insertUser();-->
<insert id="insertUser">
insert into t_book values('张三的一生','123',23f,'玄幻')
</insert>
</mapper>

 6、加入log4j日志功能

a>加入依赖

<!-- log4j日志 -->
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.17</version>
</dependency>

b>加入log4j的配置文件

This XML file does not appear to have any style information associated with it. The document tree is shown below.
<!--  status : 指定log4j本身的打印日志的级别.ALL< Trace < DEBUG < INFO < WARN < ERROR 
	< FATAL < OFF。 monitorInterval : 用于指定log4j自动重新配置的监测间隔时间,单位是s,最小是5s.  -->
<Configuration status="WARN" monitorInterval="30">
<Properties>
<!--  配置日志文件输出目录 ${sys:user.home}  -->
<Property name="LOG_HOME">/root/workspace/lucenedemo/logs</Property>
<property name="ERROR_LOG_FILE_NAME">/root/workspace/lucenedemo/logs/error</property>
<property name="WARN_LOG_FILE_NAME">/root/workspace/lucenedemo/logs/warn</property>
<property name="PATTERN">%d{yyyy-MM-dd HH:mm:ss.SSS} [%t-%L] %-5level %logger{36} - %msg%n</property>
</Properties>
<Appenders>
<!-- 这个输出控制台的配置  -->
<Console name="Console" target="SYSTEM_OUT">
<!--  控制台只输出level及以上级别的信息(onMatch),其他的直接拒绝(onMismatch)  -->
<ThresholdFilter level="trace" onMatch="ACCEPT" onMismatch="DENY"/>
<!--  输出日志的格式  -->
<!--  %d{yyyy-MM-dd HH:mm:ss, SSS} : 日志生产时间 %p : 日志输出格式 %c : logger的名称 
				%m : 日志内容,即 logger.info("message") %n : 换行符 %C : Java类名 %L : 日志输出所在行数 %M 
				: 日志输出所在方法名 hostName : 本地机器名 hostAddress : 本地ip地址  -->
<PatternLayout pattern="${PATTERN}"/>
</Console>
<!-- 文件会打印出所有信息,这个log每次运行程序会自动清空,由append属性决定,这个也挺有用的,适合临时测试用  -->
<!-- append为TRUE表示消息增加到指定文件中,false表示消息覆盖指定的文件内容,默认值是true  -->
<File name="log" fileName="logs/test.log" append="false">
<PatternLayout pattern="%d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %-5level %logger{36} - %msg%n"/>
</File>
<!--  这个会打印出所有的info及以下级别的信息,每次大小超过size, 则这size大小的日志会自动存入按年份-月份建立的文件夹下面并进行压缩,作为存档  -->
<RollingFile name="RollingFileInfo" fileName="${LOG_HOME}/info.log" filePattern="${LOG_HOME}/$${date:yyyy-MM}/info-%d{yyyy-MM-dd}-%i.log">
<!-- 控制台只输出level及以上级别的信息(onMatch),其他的直接拒绝(onMismatch)  -->
<ThresholdFilter level="info" onMatch="ACCEPT" onMismatch="DENY"/>
<PatternLayout pattern="%d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %-5level %logger{36} - %msg%n"/>
<Policies>
<!--  基于时间的滚动策略,interval属性用来指定多久滚动一次,默认是1 hour。 modulate=true用来调整时间:比如现在是早上3am,interval是4,那么第一次滚动是在4am,接着是8am,12am...而不是7am.  -->
<!--  关键点在于 filePattern后的日期格式,以及TimeBasedTriggeringPolicy的interval, 日期格式精确到哪一位,interval也精确到哪一个单位  -->
<!--  log4j2的按天分日志文件 : info-%d{yyyy-MM-dd}-%i.log  -->
<TimeBasedTriggeringPolicy interval="1" modulate="true"/>
<!--  SizeBasedTriggeringPolicy:Policies子节点, 基于指定文件大小的滚动策略,size属性用来定义每个日志文件的大小.  -->
<!--  <SizeBasedTriggeringPolicy size="2 kB" />  -->
</Policies>
</RollingFile>
<RollingFile name="RollingFileWarn" fileName="${WARN_LOG_FILE_NAME}/warn.log" filePattern="${WARN_LOG_FILE_NAME}/$${date:yyyy-MM}/warn-%d{yyyy-MM-dd}-%i.log">
<ThresholdFilter level="warn" onMatch="ACCEPT" onMismatch="DENY"/>
<PatternLayout pattern="%d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %-5level %logger{36} - %msg%n"/>
<Policies>
<TimeBasedTriggeringPolicy/>
<SizeBasedTriggeringPolicy size="2 kB"/>
</Policies>
<!--  DefaultRolloverStrategy属性如不设置,则默认为最多同一文件夹下7个文件,这里设置了20  -->
<DefaultRolloverStrategy max="20"/>
</RollingFile>
<RollingFile name="RollingFileError" fileName="${ERROR_LOG_FILE_NAME}/error.log" filePattern="${ERROR_LOG_FILE_NAME}/$${date:yyyy-MM}/error-%d{yyyy-MM-dd-HH-mm}-%i.log">
<ThresholdFilter level="error" onMatch="ACCEPT" onMismatch="DENY"/>
<PatternLayout pattern="%d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %-5level %logger{36} - %msg%n"/>
<Policies>
<!--  log4j2的按分钟 分日志文件 : warn-%d{yyyy-MM-dd-HH-mm}-%i.log  -->
<TimeBasedTriggeringPolicy interval="1" modulate="true"/>
<!--  <SizeBasedTriggeringPolicy size="10 MB" />  -->
</Policies>
</RollingFile>
</Appenders>
<!-- 然后定义logger,只有定义了logger并引入的appender,appender才会生效  -->
<Loggers>
<!-- 过滤掉spring和mybatis的一些无用的DEBUG信息  -->
<logger name="org.springframework" level="INFO"/>
<logger name="org.mybatis" level="INFO"/>
<!--  第三方日志系统  -->
<logger name="org.springframework" level="ERROR"/>
<logger name="org.hibernate" level="ERROR"/>
<logger name="org.apache.struts2" level="ERROR"/>
<logger name="com.opensymphony.xwork2" level="ERROR"/>
<logger name="org.jboss" level="ERROR"/>
<!--  配置日志的根节点  -->
<root level="all">
<appender-ref ref="Console"/>
<appender-ref ref="RollingFileInfo"/>
<appender-ref ref="RollingFileWarn"/>
<appender-ref ref="RollingFileError"/>
</root>
</Loggers>
</Configuration>

四、MyBatis的增删改查

1、添加

<!--int insert(Book record);-->
<insert id="insert" parameterType="com.zking.model.Book" >
    insert into t_book (bname, bpinyin,
      bprice, btype)
    values ( #{bname,jdbcType=VARCHAR}, #{bpinyin,jdbcType=VARCHAR},
      #{bprice,jdbcType=REAL}, #{btype,jdbcType=VARCHAR})
  </insert>

2、删除

<!--int deleteByPrimaryKey(Integer bid);-->  
<delete id="deleteByPrimaryKey" parameterType="java.lang.Integer" >
    delete from t_book
    where bid = #{bid,jdbcType=INTEGER}
  </delete>

3、修改

<!--int updateByPrimaryKey(Book record);-->  
<update id="updateByPrimaryKey" parameterType="com.zking.model.Book" >
    update t_book
    set bname = #{bname,jdbcType=VARCHAR},
      bpinyin = #{bpinyin,jdbcType=VARCHAR},
      bprice = #{bprice,jdbcType=REAL},
      btype = #{btype,jdbcType=VARCHAR}
    where bid = #{bid,jdbcType=INTEGER}
  </update>

4、查询一个实体类对象

<!--Book selectByPrimaryKey(Integer bid);-->
<select id="selectByPrimaryKey" resultMap="BaseResultMap" parameterType="java.lang.Integer" >
    select 
    <include refid="Base_Column_List" />
    from t_book
    where bid = #{bid,jdbcType=INTEGER}
  </select>

5、查询集合

<!--List<Book> queryBookAll();-->
  <select id="queryBookAll" resultType="com.zking.model.Book">
    select
    <include refid="Base_Column_List"/>
    from t_book
  </select>
举报

相关推荐

0 条评论