1.mybatis简介
Mybatis是Apache的一个Java开源项目,是一个支持动态Sql语句的持久层框架。Mybatis可以将Sql语句配置在XML文件中,避免将Sql语句硬编码在Java类中。与JDBC相比: 1)Mybatis通过参数映射方式,可以将参数灵活的配置在SQL语句中的配置文件中,避免在Java类中配置参数(JDBC) 2)Mybatis通过输出映射机制,将结果集的检索自动映射成相应的Java对象,避免对结果集手工检索(JDBC) 3)Mybatis可以通过Xml配置文件对数据库连接进行管理
2. mybatis基本构成
SqlSessionFactoryBuilder: 根据配置信息生成SqlSessionFactory SqlSessionFactory: 用于生成SqlSession SqlSession: SqlSession是MyBatis的关键对象,通过这个接口可以操作命令,管理事务等 SqlMapper:MyBatis的设计组件,有java接口和xml文件构成。需要给出对应的sql映射和映射规则
3. mybatis与hibernate的区别
两者均为ORM框架,但也有一些不同
mybatis | hibernate |
---|
轻量级 | 重量级 | 半自动化 | 全自动化 | sql | hql(但也可以使用sql,但违背了hibernate的初衷) | 扩展性、迁移性比较差 | 无缝移植 |
4. 项目中添加mybatis支持 与spring做集成
1) 使用maven新建一个web工程 2) idea在创建web工程时不会自动创建java,resources,test等目录,可以手动创建
?3)通过pom.xml添加必要的依赖,直接将相关依赖考到项目中的pom.xml文件即可。
<?xml version="1.0" encoding="UTF-8"?>
?
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
? ? ? ? xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
? ?<modelVersion>4.0.0</modelVersion>
?
? ?<groupId>org.example</groupId>
? ?<artifactId>deomMybatis</artifactId>
? ?<version>1.0-SNAPSHOT</version>
? ?<packaging>war</packaging>
?
? ?<name>deomMybatis Maven Webapp</name>
? ?<!-- FIXME change it to the project's website -->
? ?<url>http://www.example.com</url>
?
? ?<properties>
? ? ? ?<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
? ? ? ?<maven.compiler.source>1.8</maven.compiler.source>
? ? ? ?<maven.compiler.target>1.8</maven.compiler.target>
? ? ? ?<!-- jar包 版本 -->
? ? ? ?<mysql-version>8.0.29</mysql-version>
? ? ? ?<mybatis-version>3.5.9</mybatis-version>
? ? ? ?<spring-version>5.3.18</spring-version>
? ?</properties>
?
? ?<dependencies>
? ? ? ?<dependency>
? ? ? ? ? ?<groupId>junit</groupId>
? ? ? ? ? ?<artifactId>junit</artifactId>
? ? ? ? ? ?<version>4.13.1</version>
? ? ? ? ? ?<scope>test</scope>
? ? ? ?</dependency>
? ? ? ?<!-- spring 包 -->
? ? ? ?<dependency>
? ? ? ? ? ?<groupId>org.springframework</groupId>
? ? ? ? ? ?<artifactId>spring-context</artifactId>
? ? ? ? ? ?<version>${spring-version}</version>
? ? ? ?</dependency>
? ? ? ?<dependency>
? ? ? ? ? ?<groupId>org.springframework</groupId>
? ? ? ? ? ?<artifactId>spring-web</artifactId>
? ? ? ? ? ?<version>${spring-version}</version>
? ? ? ?</dependency>
? ? ? ?<dependency>
? ? ? ? ? ?<groupId>org.springframework</groupId>
? ? ? ? ? ?<artifactId>spring-tx</artifactId>
? ? ? ? ? ?<version>${spring-version}</version>
? ? ? ?</dependency>
? ? ? ?<dependency>
? ? ? ? ? ?<groupId>org.springframework</groupId>
? ? ? ? ? ?<artifactId>spring-aop</artifactId>
? ? ? ? ? ?<version>${spring-version}</version>
? ? ? ?</dependency>
? ? ? ?<dependency>
? ? ? ? ? ?<groupId>org.springframework</groupId>
? ? ? ? ? ?<artifactId>spring-test</artifactId>
? ? ? ? ? ?<version>${spring-version}</version>
? ? ? ?</dependency>
? ? ? ?<dependency>
? ? ? ? ? ?<groupId>org.springframework</groupId>
? ? ? ? ? ?<artifactId>spring-jdbc</artifactId>
? ? ? ? ? ?<version>${spring-version}</version>
? ? ? ?</dependency>
? ? ? ?<dependency>
? ? ? ? ? ?<groupId>org.springframework</groupId>
? ? ? ? ? ?<artifactId>spring-webmvc</artifactId>
? ? ? ? ? ?<version>${spring-version}</version>
? ? ? ?</dependency>
? ? ? ?<dependency>
? ? ? ? ? ?<groupId>org.springframework</groupId>
? ? ? ? ? ?<artifactId>spring-aspects</artifactId>
? ? ? ? ? ?<version>${spring-version}</version>
? ? ? ?</dependency>
?
? ? ? ?<!-- spring 集成 mybatis -->
? ? ? ?<dependency>
? ? ? ? ? ?<groupId>org.mybatis</groupId>
? ? ? ? ? ?<artifactId>mybatis-spring</artifactId>
? ? ? ? ? ?<version>2.0.6</version>
? ? ? ?</dependency>
? ? ? ?<!-- 引入阿里开发的连接池 -->
? ? ? ?<dependency>
? ? ? ? ? ?<groupId>org.apache.commons</groupId>
? ? ? ? ? ?<artifactId>commons-dbcp2</artifactId>
? ? ? ? ? ?<version>2.9.0</version>
? ? ? ?</dependency>
? ? ? ?<dependency>
? ? ? ? ? ?<groupId>org.apache.commons</groupId>
? ? ? ? ? ?<artifactId>commons-pool2</artifactId>
? ? ? ? ? ?<version>2.11.1</version>
? ? ? ?</dependency>
?
?
? ? ? ?<!-- jdbc 数据库连接 -->
? ? ? ?<dependency>
? ? ? ? ? ?<groupId>mysql</groupId>
? ? ? ? ? ?<artifactId>mysql-connector-java</artifactId>
? ? ? ? ? ?<version>${mysql-version}</version>
? ? ? ?</dependency>
? ? ? ?<!-- mybatis -->
? ? ? ?<dependency>
? ? ? ? ? ?<groupId>org.mybatis</groupId>
? ? ? ? ? ?<artifactId>mybatis</artifactId>
? ? ? ? ? ?<version>${mybatis-version}</version>
? ? ? ?</dependency>
? ? ? ?<!-- 文字转换 -->
? ? ? ?<dependency>
? ? ? ? ? ?<groupId>com.belerweb</groupId>
? ? ? ? ? ?<artifactId>pinyin4j</artifactId>
? ? ? ? ? ?<version>2.5.1</version>
? ? ? ?</dependency>
? ? ? ?<!-- 自动生成 get set 各种实体 方法 需要有lombox插件才能使用 -->
? ? ? ?<dependency>
? ? ? ? ? ?<groupId>org.projectlombok</groupId>
? ? ? ? ? ?<artifactId>lombok</artifactId>
? ? ? ? ? ?<version>1.18.22</version>
? ? ? ? ? ?<scope>provided</scope>
? ? ? ?</dependency>
?
? ? ? ?<!--日志 -->
? ? ? ?<!--日志规范接口 -->
? ? ? ?<dependency>
? ? ? ? ? ?<groupId>org.slf4j</groupId>
? ? ? ? ? ?<artifactId>slf4j-api</artifactId>
? ? ? ? ? ?<version>1.7.36</version>
? ? ? ?</dependency>
?
? ? ? ?<dependency>
? ? ? ? ? ?<groupId>ch.qos.logback</groupId>
? ? ? ? ? ?<artifactId>logback-classic</artifactId>
? ? ? ? ? ?<version>1.2.10</version>
? ? ? ?</dependency>
? ? ?<!-- servlet -->
? ? ? ?<dependency>
? ? ? ? ? ?<groupId>javax.servlet</groupId>
? ? ? ? ? ?<artifactId>javax.servlet-api</artifactId>
? ? ? ? ? ?<version>3.1.0</version>
? ? ? ? ? ?<scope>provided</scope>
? ? ? ?</dependency>
? ? ? ?<!-- 分页 -->
? ? ? ?<dependency>
? ? ? ? ? ?<groupId>com.github.pagehelper</groupId>
? ? ? ? ? ?<artifactId>pagehelper</artifactId>
? ? ? ? ? ?<version>5.1.2</version>
? ? ? ?</dependency>
? ? ? ?<!-- JSTL依赖 原因:org.springframework.web.servlet.view.JstlView在视图解析时需要这二个jar包-->
? ? ? ?<dependency>
? ? ? ? ? ?<groupId>jstl</groupId>
? ? ? ? ? ?<artifactId>jstl</artifactId>
? ? ? ? ? ?<version>1.2</version>
? ? ? ?</dependency>
? ? ? ?<dependency>
? ? ? ? ? ?<groupId>taglibs</groupId>
? ? ? ? ? ?<artifactId>standard</artifactId>
? ? ? ? ? ?<version>1.1.2</version>
? ? ? ?</dependency>
?
? ?</dependencies>
?
? ?<build>
? ? ? ?<finalName>deomMybatis</finalName>
? ? ? ?<pluginManagement><!-- lock down plugins versions to avoid using Maven defaults (may be moved to parent pom) -->
? ? ? ? ? ?<plugins>
?
? ? ? ? ? ? ? ?<plugin>
? ? ? ? ? ? ? ? ? ?<groupId>org.apache.maven.plugins</groupId>
? ? ? ? ? ? ? ? ? ?<artifactId>maven-clean-plugin</artifactId>
? ? ? ? ? ? ? ? ? ?<version>3.1.0</version>
? ? ? ? ? ? ? ?</plugin>
? ? ? ? ? ? ? ?<!-- see http://maven.apache.org/ref/current/maven-core/default-bindings.html#Plugin_bindings_for_war_packaging -->
? ? ? ? ? ? ? ?<plugin>
? ? ? ? ? ? ? ? ? ?<groupId>org.apache.maven.plugins</groupId>
? ? ? ? ? ? ? ? ? ?<artifactId>maven-resources-plugin</artifactId>
? ? ? ? ? ? ? ? ? ?<version>3.0.2</version>
? ? ? ? ? ? ? ?</plugin>
? ? ? ? ? ? ? ?<plugin>
? ? ? ? ? ? ? ? ? ?<groupId>org.apache.maven.plugins</groupId>
? ? ? ? ? ? ? ? ? ?<artifactId>maven-compiler-plugin</artifactId>
? ? ? ? ? ? ? ? ? ?<version>3.8.0</version>
? ? ? ? ? ? ? ?</plugin>
? ? ? ? ? ? ? ?<plugin>
? ? ? ? ? ? ? ? ? ?<groupId>org.apache.maven.plugins</groupId>
? ? ? ? ? ? ? ? ? ?<artifactId>maven-surefire-plugin</artifactId>
? ? ? ? ? ? ? ? ? ?<version>2.22.1</version>
? ? ? ? ? ? ? ?</plugin>
? ? ? ? ? ? ? ?<plugin>
? ? ? ? ? ? ? ? ? ?<groupId>org.apache.maven.plugins</groupId>
? ? ? ? ? ? ? ? ? ?<artifactId>maven-war-plugin</artifactId>
? ? ? ? ? ? ? ? ? ?<version>3.2.2</version>
? ? ? ? ? ? ? ?</plugin>
? ? ? ? ? ? ? ?<plugin>
? ? ? ? ? ? ? ? ? ?<groupId>org.apache.maven.plugins</groupId>
? ? ? ? ? ? ? ? ? ?<artifactId>maven-install-plugin</artifactId>
? ? ? ? ? ? ? ? ? ?<version>2.5.2</version>
? ? ? ? ? ? ? ?</plugin>
? ? ? ? ? ? ? ?<plugin>
? ? ? ? ? ? ? ? ? ?<groupId>org.apache.maven.plugins</groupId>
? ? ? ? ? ? ? ? ? ?<artifactId>maven-deploy-plugin</artifactId>
? ? ? ? ? ? ? ? ? ?<version>2.8.2</version>
? ? ? ? ? ? ? ?</plugin>
? ? ? ? ? ? ? ?<!-- 设置单元测试错误可 编译打包代码 -->
? ? ? ? ? ? ? ?<plugin>
? ? ? ? ? ? ? ? ? ?<groupId>org.apache.maven.plugins</groupId>
? ? ? ? ? ? ? ? ? ?<artifactId>maven-surefire-plugin</artifactId>
? ? ? ? ? ? ? ? ? ?<configuration>
? ? ? ? ? ? ? ? ? ? ? ?<testFailureIgnore>true</testFailureIgnore>
? ? ? ? ? ? ? ? ? ?</configuration>
? ? ? ? ? ? ? ?</plugin>
?
?
? ? ? ? ? ?</plugins>
? ? ? ?</pluginManagement>
? ?</build>
</project>
?
4)将mybatis 配置到spring中的 核心配置文件(applicationContext-base.xml),jdbc.properties 连接参数, logback.xml日志考到项目的resources目录下,并修改数据库的连接。
applicationContext-base.xml spring核心配置文件
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
? ? ? xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:aop="http://www.springframework.org/schema/aop"
? ? ? xmlns:context="http://www.springframework.org/schema/context" xmlns:tx="http://www.springframework.org/schema/tx"
? ? ? xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.2.xsd
http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-4.3.xsd
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.3.xsd
http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-4.3.xsd">
?
? ?<!--1. 注解式开发 -->
? ?<!--1) 注解驱动,用于激活已经在spring容器中注册过的bean上面的注解-->
? ?<!--<context:annotation-config/>-->
? ?<!-- 2) 用注解方式注入bean,并指定查找范围:com.zking.oa及子子孙孙包,使用了该注解后,context:annotation-config注解可以省略 -->
? ?<context:component-scan base-package="com.zking.mybatis01"/>
?
? ?<!--2. 引入外置jdbc配置文件 -->
? ?<!-- 第一种方式
? ?<bean id="propertyConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
? ? ? ?<property name="location" value="classpath:jdbc.properties"/>
? ?</bean>
? ?-->
? ?<!--ignore-resource-not-found 不配置的话 会绑定斯读取的参数 -->
? ?<!-- 第二种方式,比第一种方式更简洁,第一种方式更好理解一些 -->
? ?<context:property-placeholder location="classpath:jdbc.properties" ignore-resource-not-found="true"/>
?
? ?<!-- 3. dbcp2数据库连接池配置 阿里云-->
? ?<bean id="dataSource" class="org.apache.commons.dbcp2.BasicDataSource"
? ? ? ? ?destroy-method="close">
? ? ? ?<property name="driverClassName" value="${driver.name}"/>
? ? ? ?<property name="url" value="${db.url}"/>
? ? ? ?<property name="username" value="${db.user}"/>
? ? ? ?<property name="password" value="${db.password}"/>
? ? ? ?<!--初始连接数-->
? ? ? ?<property name="initialSize" value="10"/>
? ? ? ?<!--最大活动连接数-->
? ? ? ?<property name="maxTotal" value="100"/>
? ? ? ?<!--最大空闲连接数-->
? ? ? ?<property name="maxIdle" value="50"/>
? ? ? ?<!--最小空闲连接数-->
? ? ? ?<property name="minIdle" value="10"/>
? ? ? ?<!--设置为-1时,如果没有可用连接,连接池会一直无限期等待,直到获取到连接为止。-->
? ? ? ?<!--如果设置为N(毫秒),则连接池会等待N毫秒,等待不到,则抛出异常-->
? ? ? ?<property name="maxWaitMillis" value="-1"/>
? ? ? ? ?<!-- mysql 8小时问题 需要定时发送sql 执行 -->
? ? ? ?<property name="testWhileIdle" value="true"></property>
? ? ? ?<property name="validationQuery" value="select 1"></property>
?
? ?</bean>
?
? ?<!--4. spring和MyBatis整合 -->
? ?<!--1) 创建sqlSessionFactory-->
? ?<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
? ? ? ?<!-- 指定数据源 -->
? ? ? ?<property name="dataSource" ref="dataSource"/>
? ? ? ?<!-- 指定mybatis核心配置文件 -->
? ? ? ?<!-- <property name="configLocation" value="classpath:mybatis.cfg.xml"/>-->
? ? ? ?<!-- 自动扫描XxxMapping.xml文件,**表示迭代查找 -->
? ? ? ?<property name="mapperLocations" value="classpath:/mapper/**/*.xml"/>
?
? ? ? ?<property name="plugins">
? ? ? ? ? ?<list>
? ? ? ? ? ? ? ?<bean class="com.github.pagehelper.PageInterceptor">
? ? ? ? ? ? ? ? ? ?<property name="properties">
? ? ? ? ? ? ? ? ? ? ? ?<!-- config params as the following -->
? ? ? ? ? ? ? ? ? ? ? ?<value>
? ? ? ? ? ? ? ? ? ? ? ? ? helperDialect=mysql
? ? ? ? ? ? ? ? ? ? ? ?</value>
? ? ? ? ? ? ? ? ? ?</property>
? ? ? ? ? ? ? ?</bean>
? ? ? ? ? ?</list>
? ? ? ?</property>
?
? ?</bean>
?
? ?<!--2) 自动扫描com/zking/oa/**/mapper下的所有XxxMapper接口(其实就是DAO接口),并实现这些接口-->
? ?<!-- ? 即可直接在程序中使用dao接口,不用再获取sqlsession对象-->
? ?<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
? ? ? ?<!--basePackage 属性是映射器接口文件的包路径。-->
? ? ? ?<!--你可以使用分号或逗号 作为分隔符设置多于一个的包路径-->
? ? ? ?<property name="basePackage" value="com/zking/**/mapper"/>
? ? ? ?<property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"/>
? ?</bean>
?
? ?<!--5. 声明式事务配置开始 -->
? ?<!--1) 开启自动代理 -->
? ?<aop:aspectj-autoproxy/>
?
? ?<!--2) 事务管理器 -->
? <bean id="transactionManager"
? ? ? ? ?class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
? ? ? ?<property name="dataSource" ref="dataSource"/>
? ?</bean>
?
? ?<!-- 注解式事务 -->
? ?<tx:annotation-driven transaction-manager="transactionManager"/>
?
</beans>
jdbc.properties mysql 8.0 连接配置文件
driver.name=com.mysql.cj.jdbc.Driver
db.url=jdbc:mysql://localhost:3306/test?useSSL=false&serverTimezone=Asia/Shanghai&characterEncoding=utf-8&allowPublicKeyRetrieval=true
db.user=root
db.password=123456
logback.xml 配置日志文件
<?xml version="1.0" encoding="UTF-8"?>
<configuration debug="false">
?
? ?<!--定义日志文件的存储地址,勿在LogBack 的配置中使用相对路径-->
? ?<property name="LOG_HOME" value="d:\\temp\\mylogs" />
? ?<!-- 定义项目名称 -->
? ?<property name="LOG_NAME" value="mybatisdemo"/>
?
? ?<!-- 控制台输出 -->
? ?<appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
? ? ? ?<encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
? ? ? ? ? ?<!--格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度%msg:日志消息,%n是换行符-->
? ? ? ? ? ?<pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n</pattern>
? ? ? ?</encoder>
? ?</appender>
?
? ?<!-- 日志滚动输出,按日期滚动 -->
? ?<appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
? ? ? ?<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
? ? ? ? ? ?<!--日志文件输出的文件名-->
? ? ? ? ? ?<FileNamePattern>${LOG_HOME}/${LOG_NAME}.%d{yyyy-MM-dd}.log</FileNamePattern>
? ? ? ? ? ?<!--日志文件保留天数-->
? ? ? ? ? ?<MaxHistory>30</MaxHistory>
? ? ? ?</rollingPolicy>
? ? ? ?<encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
? ? ? ? ? ?<!--格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度%msg:日志消息,%n是换行符-->
? ? ? ? ? ?<pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n</pattern>
? ? ? ?</encoder>
? ? ? ?<!--日志文件最大的大小-->
? ? ? ?<triggeringPolicy class="ch.qos.logback.core.rolling.SizeBasedTriggeringPolicy">
? ? ? ? ? ?<MaxFileSize>10MB</MaxFileSize>
? ? ? ?</triggeringPolicy>
? ?</appender>
?
? ?<!-- myibatis 相关的日志配置,适合开发环境,便于调试 -->
? ?<!--<logger name="com.apache.ibatis" level="TRACE"/>
? ?<logger name="java.sql.Connection" level="DEBUG"/>
? ?<logger name="java.sql.Statement" level="DEBUG"/>
? ?<logger name="java.sql.PreparedStatement" level="DEBUG"/>-->
?
? ?<!-- 日志输出级别 -->
? ?<!-- 级别排序为: TRACE < DEBUG < INFO < WARN < ERROR -->
? ?<root level="INFO">
? ? ? ?<appender-ref ref="STDOUT" />
? ? ? ?<appender-ref ref="FILE"/>
? ?</root>
?
</configuration>
5) 在src/main/resources目录下创建mapper用于方式mybatis的映射文件
?6)创建包的目录结构,如下图所示:
?7)ssh2与ssm的对应关系
ssh2 | ssm |
---|
action | controller | service | service | dao | mapper | IXxxDao.java | XxxMapper | XxxDao.java | XxxMapper.xml | entity | model | Xxx.java | Xxx.java | Xxx.hbm.xml | |
8)编写model,即存放数据的对象,在ssh2时叫做entity。
这里就可以看到 我们所用的lombok的强大的 @Data 会自动生成 get set 与tostring 等等。。。。
使用lombok需要有的插件
?
?
9)mapper编写(相当于dao)。
编写之前我们需下载一个插件方便编写mybatis 如下图
?
10)在目录结构中加入一个mapper包,在该包中创建一个TestMapper接口
创建好接口后 ----可直接使用插件生成 mybatis的xml配置文件
?
注意 :第一次创建的时候会提示你选择地址 我们直接选择 resources 中我们创建的mapper文件
?
?
~我们用student实体来做一个查询的实例 使用方式 spring注解注入
1.mapper中定义的接口
package com.zking.mybatis01.mapper;
?
import com.zking.mybatis01.dto.StudentDto;
import com.zking.mybatis01.model.Student;
?
import org.springframework.stereotype.Repository;
?
import java.util.List;
@Repository("studentMapper")
public interface IStudentMapper {
? ?/**
? ? * 查询所有学生
? ? * @param stu 根据姓名 模糊查询
? ? * @return 返回 学生集合
? ? */
? ?public List<Student> listStudent(Student stu);
?
? ?/**
? ? * 增加学生
? ? * @param stu 学生实体
? ? */
? public Integer addStudent(Student stu);
?
? ?/**
? ? * 修改学生信息
? ? * @param upd
? ? * @return
? ? */
? public Integer updStudent(Student upd);
?
? ?/**
? ? * 根据学生id 进行删除
? ? * @param stu
? ? * @return
? ? */
? Integer delStudent(Student stu);
?
? ?/**
? ? * 根据 用户多个id查询
? ? * @return
? ? */
? List<Student> listStudentByid(StudentDto dto);
?
}
注意:在xml中注释的方法要在对应的java接口中注释掉,(注释掉只是为了少写点代码,尽快测试)
注:#{} 与 ${} 的区别 #{ }是预编译处理,MyBatis在处理#{ }时,它会将sql中的#{ }替换为?,然后调用PreparedStatement的set方法来赋值,传入字符串后,会在值两边加上单引号,如上面的值 “4,44,514”就会变成“ ‘4,44,514’ ”
${ }是字符串替换, MyBatis在处理${ }时,它会将sql中的${ }替换为变量的值,传入的数据不会加两边加上单引号。
使用${ }会导致sql注入,不利于系统的安全性!
SQL注入:就是通过把SQL命令插入到Web表单提交或输入域名或页面请求的查询字符串,最终达到欺骗服务器执行恶意的SQL命令。常见的有匿名登录(在登录框输入恶意的字符串)、借助异常获取数据库信息等
2.如数据库与实体的属性名不一致 需要配置映射关系 如图:👇
?2.1 .我们配置好的 增删改查
<?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.zking.mybatis01.mapper.IStudentMapper">
?
? ?<!-- 查询所有 -->
? ?<select id="listStudent" resultType="com.zking.mybatis01.model.Student">
? ? ? select sid,sname,birthday,ssex
? ? ? FROM t_student
? ? ?<where>
? ? ? ? ?<if test="sname !=null and ''!=sname ">
? ? ? ? ? ? ? sname like concat(#{sname},'%')
? ? ? ? ?</if>
? ? ?</where>
? ?</select>
? ?<!-- 根据用户提供的多个id 进行查询 -->
? ?<select id="listStudentByid" resultType="com.zking.mybatis01.model.Student">
? ? ? select sid,sname,birthday,ssex from t_student
<where>
? ?<choose>
?
? ? ? <when test="listSid != null and listSid.size != 0">
? ? ? ? ? and sid in
? ? ? ? ? <!-- collection 循环的属性名 ? item 循环中应用的名字 open 以什么开头 close 结尾 ? separator 循环一个后以,隔开 ? -->
? ? ? ? <foreach collection="listSid" item="sid" open="(" close=")" separator=",">
? ? ? ? ? ? #{sid}
? ? ? ? </foreach>
? ? ? </when>
? ?</choose>
</where>
?
? ?</select>
?
? ?<!-- 增加学生 -->
? ?<insert id="addStudent" parameterType="com.zking.mybatis01.model.Student">
? Insert into t_student (sname,birthday,ssex)
? values (#{sname},#{birthday},#{ssex})
?
? ?</insert>
?<!-- 修改学生信息 -->
? ?<update id="updStudent" ?parameterType="com.zking.mybatis01.model.Student">
? ? update t_student
? ? <set>
? ? ? <if test="sname !=null and ''!=sname">
? ? ? ? ? sname = #{sname},
? ? ? </if>
? ? ? ? <if test="birthday !=null">
? ? ? ? ? ? birthday = #{birthday},
? ? ? ? </if>
? ? ? ? <if test="ssex !=null and ''!=ssex">
? ? ? ? ? ? ssex = #{ssex,jdbcType=NUMERIC}
? ? ? ? </if>
? ? </set>
? ? ?<where>
? ? ? ? ? sid = #{sid}
? ? ?</where>
? ?</update>
<!-- 根据id 进行删除 -->
? ?<delete id="delStudent" parameterType="com.zking.mybatis01.model.Student">
? ? ? delete from t_student <where>
? ? ? sid = #{sid}
? ?</where>
?
? ?</delete>
</mapper>
3.接下来我们编写service 事务层
定义我们的service接口 ↓
package com.zking.mybatis01.service;
?
import com.zking.mybatis01.dto.StudentDto;
import com.zking.mybatis01.model.Student;
import com.zking.mybatis01.utils.PageBean;
?
import java.util.List;
?
public interface IStudentService {
?
?
? ?/**
? ? * 查询所有学生信息
? ? * @param stu 模糊查询
? ? * @return 学生集合
? ? */
? ?List<Student> listStudentpaging(Student stu , PageBean pge);
? ?/**
? ? * 增加学生
? ? * @param stu 学生实体
? ? */
? ?Integer addStudent(Student stu);
? ?/**
? ? * 修改学生信息
? ? * @param upd
? ? * @return
? ? */
? ?public Integer updStudent(Student upd);
? ?/**
? ? * 根据学生id 进行删除
? ? * @param stu
? ? * @return
? ? */
? ?Integer delStudent(Student stu);
? ?/**
? ? * 根据 用户多个id查询
? ? * @return
? ? */
? ?List<Student> listStudentByid(StudentDto dto );
}
定义实现类
package com.zking.mybatis01.service;
?
import com.github.pagehelper.PageHelper;
import com.github.pagehelper.PageInfo;
import com.zking.mybatis01.dto.StudentDto;
import com.zking.mybatis01.interfaces.Paging;
import com.zking.mybatis01.mapper.IStudentMapper;
import com.zking.mybatis01.model.Student;
import com.zking.mybatis01.utils.PageBean;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.stereotype.Service;
?
import javax.annotation.Resource;
import java.util.List;
@Service
public class StudentServiceImpl implements IStudentService {
? //类型判断 注入
? ?@Autowired
? ?private IStudentMapper stu;
?
?
? ?@Override
? ?public List<Student> listStudentpaging(Student stu, PageBean pge) {
?
?
? ? ? ?return ?this.stu.listStudent(stu);
? }
?
? ?@Override
? ?public Integer addStudent(Student stu) {
? ? ? return ? this.stu.addStudent(stu);
? }
?
? ?@Override
? ?public Integer updStudent(Student upd) {
? ? ? ?return this.stu.updStudent(upd);
? }
?
? ?@Override
? ?public Integer delStudent(Student stu) {
? ? ? ?return this.stu.delStudent(stu);
? }
?
? ?@Override
? ?public List<Student> listStudentByid(StudentDto dto) {
? ? ? ?return this.stu.listStudentByid(dto);
? }
}
?
?
编写测试用例 测试功能
部分测试
package com.zking.mybatis01.service;
?
import com.zking.mybatis01.dto.StudentDto;
import com.zking.mybatis01.model.Student;
import com.zking.mybatis01.utils.PageBean;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
?
import java.util.Arrays;
import java.util.Date;
import java.util.List;
//帮我们去生成spring 上下文对象
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations={"classpath*:applicationContext*.xml"})
public class StudentServiceImplTest {
? ?@Autowired
? ?private IStudentService studentService;
?
?
? ?@Test
? ?public void listStudent() {
? ? ? ?Student st=new Student();
? ? ? ?st.setBirthday(new Date());
? ? ? ?st.setSname("小黑");
? ? ? ?st.setSsex(1);
? ? ? ?/*List<Student> students = studentService.listStudent(st);
? ? ? ?students.forEach(t->System.out.println(t));*/
?
? ? ?Integer i= ?studentService.addStudent(st);
? ? ? ?System.out.println(i);
?
? }
? ?@Test
? ?public void updStudent(){
? ? ? ?Student st=new Student();
? ? ? ?st.setSid(1);
? ? ? ?st.setBirthday(new Date());
? ? ? ?st.setSname("小名");
? ? ? ?st.setSsex(1);
? ? ? ?Integer integer = studentService.updStudent(st);
? ? ? ?System.out.println(integer);
? }
? ?@Test
? public void delStudent(){
? ? ? Student st=new Student();
? ? ? st.setSid(18);
? ? ? Integer integer = studentService.delStudent(st);
? ? ? System.out.println(integer);
? }
? @Test
public void listStudentByid(){
? ? ? StudentDto studentDto = new StudentDto();
? ? ? studentDto.setListSid(Arrays.asList(1,2,3,5,6));
? ? ? List<Student> students = studentService.listStudentByid(studentDto);
? ? ? students.forEach(System.out::println);
? }
?
}
5.分页 插件 pagehelper 的实现 使用spring切面与自定义注解实现功能
引入pagehelper 包 如果复制了上方的pom的 可不需要加入
<!-- 分页 -->
<dependency>
? ?<groupId>com.github.pagehelper</groupId>
? ?<artifactId>pagehelper</artifactId>
? ?<version>5.1.2</version>
</dependency>
1.编写分页实体便于分页
package com.zking.mybatis01.utils;
?
import com.mysql.cj.util.StringUtils;
?
import java.util.Map;
?
import javax.servlet.http.HttpServletRequest;
?
?
?
public class PageBean {
?
/**
* 页码
*/
private int page = 1;
?
/**
* 每页显示的记录数
*/
private int rows = 10;
?
/**
* 总记录数
*/
private int total = 0;
?
/**
* 是否分页
*/
private boolean pagination = true;
?
/**
* 记录查询的url,以便于点击分页时再次使用
*/
private String url;
?
/**
* 存放请求参数,用于生成隐藏域中的元素
*/
private Map<String,String[]> parameterMap;
?
/**
* 根据传入的Request初始化分页对象
* @param request
*/
public void setRequest(HttpServletRequest request) {
?
if(!StringUtils.isNullOrEmpty(request.getParameter("page"))) {
this.page = Integer.valueOf(request.getParameter("page"));
}
if(!StringUtils.isNullOrEmpty(request.getParameter("rows"))) {
this.rows = Integer.valueOf(request.getParameter("rows"));
}
if(!StringUtils.isNullOrEmpty(request.getParameter("pagination"))) {
this.pagination = Boolean.valueOf(request.getParameter("pagination"));
}
?
this.url = request.getRequestURI();
this.parameterMap = request.getParameterMap();
?
request.setAttribute("pageBean", this);
}
?
?
public int getPage() {
return page;
}
?
?
public void setPage(int page) {
this.page = page;
}
?
?
public int getRows() {
return rows;
}
?
?
public void setRows(int rows) {
this.rows = rows;
}
?
?
public int getTotal() {
return total;
}
?
?
public void setTotal(int total) {
this.total = total;
}
?
public boolean isPagination() {
return pagination;
}
?
public void setPagination(boolean pagination) {
this.pagination = pagination;
}
?
public String getUrl() {
return url;
}
?
public void setUrl(String url) {
this.url = url;
}
?
public Map<String, String[]> getParameterMap() {
return parameterMap;
}
?
public void setParameterMap(Map<String, String[]> parameterMap) {
this.parameterMap = parameterMap;
}
?
//计算起始页码
public int getStartIndex() {
return (this.page - 1) * this.rows;
}
?
//获取总页数
public int getTotalPage() {
if (this.getTotal() % this.rows == 0) {
return this.getTotal() / this.rows;
} else {
return this.getTotal() / this.rows + 1;
}
}
?
//上一页
public int getPreviousPage() {
return this.page - 1 > 0 ? this.page - 1 : 1;
}
?
//下一页
public int getNextPage() {
return this.page + 1 > getTotalPage() ? getTotalPage() : this.page + 1;
}
?
}
2.在aop包中定义分页切面
?
package com.zking.mybatis01.aop;
?
import com.github.pagehelper.PageHelper;
import com.github.pagehelper.PageInfo;
import com.zking.mybatis01.utils.PageBean;
import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.After;
import org.aspectj.lang.annotation.Around;
import org.aspectj.lang.annotation.Aspect;
import org.springframework.stereotype.Component;
?
import java.util.List;
?
@Component
@Aspect
public class PaginAop {
? ?//环绕通知 自定义注解 分辨是否调用
? ?@Around("@annotation(com.zking.mybatis01.interfaces.Paging)")
? ?public Object around(ProceedingJoinPoint joinPoint) throws Throwable {
? ? ? //获取目标方法的所有参数
? ? ? ?Object[] args = joinPoint.getArgs();
? ? ? ?PageBean pag =null;
? ? ? ?for (Object arg : args) {
? ? ? ? ? ?if(arg instanceof PageBean){
? ? ? ? ? ? ? ? pag=(PageBean) arg;
? ? ? ? ? ? ? ?if(pag!=null && pag.isPagination()){
? ? ? ? ? ? ? ? ? ?PageHelper.startPage(pag.getPage(),pag.getRows());
? ? ? ? ? ? ? }
? ? ? ? ? }
? ? ? }
? ? ? ?Object proceed = joinPoint.proceed();
? ? ? ?if(pag!=null && pag.isPagination()){
? ? ? ? ? ?PageInfo info=new PageInfo((List) proceed);
? ? ? ? ? ?pag.setTotal((int)info.getTotal());
? ? ? }
? ? ? ?return ?proceed;
? }
?
?
}
?2.1 注解编写
?
接下来我们就可以去使用注解了
1.我们将自定义注解标记在我们需要分页的方法上 在service中实现
?
2.测试用例中添加
?
? @Test
?public void listStudentPage(){
? ? ? PageBean page=new PageBean();
? ? ? page.setRows(3);
? ? ? List<Student> students = studentService.listStudentpaging(null, page);
? ? ? students.forEach(System.out::println);
? }
?
3.运行结果
?
|